**Preliminary User's Manual** 

NEC

# **USB Host Controller**

 $\mu$ PD9210FGC-7EA

Document No. A13286EJ1V0UM00 (1st edition) Date Published July 1998 N CP(N)

© NEC Corporation 1998 Printed in Japan [MEMO]

#### **1** PRECAUTION AGAINST ESD FOR SEMICONDUCTORS

#### Note:

Strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it once, when it has occurred. Environmental control must be adequate. When it is dry, humidifier should be used. It is recommended to avoid using insulators that easily build static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work bench and floor should be grounded. The operator should be grounded using wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with semiconductor devices on it.

#### (2) HANDLING OF UNUSED INPUT PINS FOR CMOS

#### Note:

No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using a pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND with a resistor, if it is considered to have a possibility of being an output pin. All handling related to the unused pins must be judged device by device and related specifications governing the devices.

#### **③** STATUS BEFORE INITIALIZATION OF MOS DEVICES

#### Note:

Power-on does not necessarily define initial status of MOS device. Production process of MOS does not define the initial operation status of the device. Immediately after the power source is turned ON, the devices with reset function have not yet been initialized. Hence, power-on does not guarantee out-pin levels, I/O settings or contents of registers. Device is not initialized until the reset signal is received. Reset operation must be executed immediately after power-on for devices having reset function.

PC/AT is a trademark of IBM Corp.

The application circuits and their parameters are for reference only and are not intended for use in actual design-ins.

The export of this product from Japan is regulated by the Japanese government. To export this product may be prohibited without governmental license, the need for which must be judged by the customer. The export or re-export of this product from a country other than Japan may also be prohibited without a license from that country. Please call an NEC sales representative.

#### The information in this document is subject to change without notice.

No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document.

NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from use of a device described herein or any other liability arising from use of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Corporation or others.

While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features.

NEC devices are classified into the following three quality grades:

"Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application.

- Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots
- Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support)
- Specific: Aircrafts, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc.

The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance.

Anti-radioactive design is not implemented in this product.

# **Regional Information**

Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify:

- · Device availability
- · Ordering information
- Product release schedule
- · Availability of related technical literature
- Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth)
- Network requirements

In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country.

| NEC Electronics Inc. (U.S.)<br>Santa Clara, California<br>Tel: 408-588-6000<br>800-366-9782<br>Fax: 408-588-6130         | <b>NEC Electronics (Germany) GmbH</b><br>Benelux Office<br>Eindhoven, The Netherlands<br>Tel: 040-2445845<br>Fax: 040-2444580 | NEC Electronics Hong Kong Ltd.<br>Hong Kong<br>Tel: 2886-9318<br>Fax: 2886-9022/9044                                                                              |
|--------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 800-729-9288<br><b>NEC Electronics (Germany) GmbH</b><br>Duesseldorf, Germany<br>Tel: 0211-65 03 02                      | NEC Electronics (France) S.A.<br>Velizy-Villacoublay, France<br>Tel: 01-30-67 58 00<br>Fax: 01-30-67 58 99                    | NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Seoul, Korea<br>Tel: 02-528-0303<br>Fax: 02-528-4411                                                            |
| Fax: 0211-65 03 490<br><b>NEC Electronics (UK) Ltd.</b><br>Milton Keynes, UK<br>Tel: 01908-691-133<br>Fax: 01908-670-290 | <b>NEC Electronics (France) S.A.</b><br>Spain Office<br>Madrid, Spain<br>Tel: 01-504-2787<br>Fax: 01-504-2860                 | NEC Electronics Singapore Pte. Ltd.<br>United Square, Singapore 1130<br>Tel: 65-253-8311<br>Fax: 65-250-3583                                                      |
| <b>NEC Electronics Italiana s.r.1.</b><br>Milano, Italy<br>Tel: 02-66 75 41<br>Fax: 02-66 75 42 99                       | NEC Electronics (Germany) GmbH<br>Scandinavia Office<br>Taeby, Sweden<br>Tel: 08-63 80 820<br>Fax: 08-63 80 388               | NEC Electronics Taiwan Ltd.<br>Taipei, Taiwan<br>Tel: 02-719-2377<br>Fax: 02-719-5951<br>NEC do Brasil S.A.<br>Cumbica-Guarulhos-SP, Brasil<br>Tel: 011-6465-6810 |

J98. 2

Fax: 011-6465-6829

[MEMO]

#### PREFACE

This manual describes a USB host controller that complies with the **Open Host Controller Interface Specification Release 1.0** and **OpenHCI Legacy Support Interface Specification Release Version 1.01**.

Read this manual thoroughly to help ensure smooth system design. Also, be sure to observe the various notes in this manual (general notes, caution points, and restrictions). Operation faults and a reduction in the quality and performance levels of LSI products may occur if these notes are not observed.

Before starting a design, contact your local NEC sales representative or distributor to make sure you have the most recent documentation.

## CONTENTS

| CHAPTE | R 1 FEATURES                                            | 15 |
|--------|---------------------------------------------------------|----|
| 1.1    | Features                                                | 15 |
| 1.2    | Block Diagram                                           | 17 |
| 1.3    | Pin Configuration                                       | 18 |
| 1.4    | Pin Configuration Diagram                               | 19 |
| 1.5    | Pin Names and Pin Numbers                               | 20 |
| СНАРТЕ | R 2 PIN FUNCTIONS                                       | 21 |
| 2.1    | Pin Table                                               | 21 |
| 2.2    | Description of Pin Functions                            | 23 |
| 2.3    | Handling Unused Pins                                    | 26 |
| СНАРТЕ | R 3 DESCRIPTION OF USB HOST CONTROLLER FUNCTIONS        | 27 |
| 3.1    | Overview of USB                                         | 27 |
| 3.2    | Host Controller's Communication Method                  | 30 |
| 3.3    | Endpoint Descriptor                                     | 33 |
|        | 3.3.1 Endpoint descriptor format                        | 33 |
|        | 3.3.2 Endpoint descriptor field definitions             | 34 |
| 3.4    | Transfer Descriptors                                    | 35 |
|        | 3.4.1 General transfer descriptor format                | 35 |
|        | 3.4.2 General transfer descriptor field definitions     | 36 |
|        | 3.4.3 Isochronous transfer descriptor format            | 37 |
|        | 3.4.4 Isochronous transfer descriptor field definitions | 38 |
| 3.5    | Host Controller Communications Area                     | 39 |
|        | 3.5.1 Host controller communications area format        | 39 |
|        | 3.5.2 Host controller communications area description   | 39 |
| 3.6    | HC Mode Changes                                         | 40 |
| 3.7    | List Service Flow                                       | 41 |
| 3.8    | Legacy Operations                                       | 45 |
| CHAPTE | R 4 POWER MANAGEMENT                                    | 51 |
| 4.1    | Overview of Power Management                            | 51 |
| 4.2    | Bus States and Device States                            | 52 |
| 4.3    | Transition Conditions for Bus States and Device States  | 53 |
| 4.4    | Device State Transition Flow                            | 55 |
| CHAPTE | R 5 REGISTER INFORMATION                                | 59 |
| 5.1    | PCI Configuration Space                                 | 59 |
| 5.2    | Operational Registers                                   | 64 |
|        | 5.2.1 Overview of operational registers                 | 65 |
|        |                                                         |    |

|        | 5.2.2 Overview of legacy support registers                                         | 74 |
|--------|------------------------------------------------------------------------------------|----|
| CHAPTE | R 6 ELECTRICAL CHARACTERISTICS                                                     | 77 |
| 6.1    | Buffer List                                                                        | 77 |
| 6.2    | Absolute Maximum Ratings                                                           | 78 |
| 6.3    | Recommended Operating Conditions                                                   | 78 |
| 6.4    | Pin Capacitance                                                                    | 78 |
| 6.5    | DC Characteristics (V <sub>DD</sub> = 3.0 V to 3.6 V, T <sub>A</sub> = 0 to +70°C) | 79 |
| 6.6    | Power Consumption                                                                  | 83 |
| 6.7    | System Clock Ratings                                                               | 83 |
| 6.8    | AC Characteristics (V <sub>DD</sub> = 3.0 V to 3.6 V, T <sub>A</sub> = 0 to +70°C) | 84 |
| CHAPTE | R 7 TIMING CHARTS                                                                  | 87 |
| 7.1    | PCI Clock                                                                          | 87 |
| 7.2    | PCI Reset                                                                          | 87 |
| 7.3    | PCI Output Timing                                                                  | 88 |
| 7.4    | PCI Input Timing                                                                   | 88 |
| 7.5    | PCI Clock Reset                                                                    | 88 |
| 7.6    | CRUN vs. GNT                                                                       | 89 |
| 7.7    | USB Device Disconnect Detection                                                    | 89 |
| 7.8    | USB Full Speed Device Connect Detection                                            | 89 |
| 7.9    | USB Low Speed Device Connect Detection                                             | 90 |
| 7.10   | USB Signal Rise/Fall Timing                                                        | 90 |
| 7.11   | USB Differential Signal                                                            | 90 |
| 7.12   | USB EOP Signal                                                                     | 91 |
| 7.13   | USB Differential Receiver Allowable Jitter                                         | 91 |
| CHAPTE | R 8 USB HOST CONTROLLER USE METHOD                                                 | 93 |
| 8.1    | USB Host Controller Peripheral Circuit Example                                     | 93 |

| Figure | No. Title                                                                     | Page |
|--------|-------------------------------------------------------------------------------|------|
|        |                                                                               |      |
| 1-1    | Block Diagram                                                                 | 17   |
| 1-2    | Pin Configuration                                                             | 18   |
| 1-3    | Pin Configuration Diagram                                                     | 19   |
| 3-1    | Bus Topology                                                                  | 27   |
| 3-2    | Full Speed Device Cable and Resistor Connections                              | 28   |
| 3-3    | Low Speed Device Cable and Resistor Connections                               | 28   |
| 3-4    | Relation between EDs and TDs                                                  | 30   |
| 3-5    | Interrupt ED List                                                             | 31   |
| 3-6    | Allocation of Bandwidth                                                       | 31   |
| 3-7    | When Control/Bulk Service Ratio Is 4:1                                        | 32   |
| 3-8    | Endpoint Descriptor Format                                                    | 33   |
| 3-9    | General TD Format                                                             | 35   |
| 3-10   | Current Buffer Pointer/Buffer End and 4-K Boundary                            | 37   |
| 3-11   | Isochronous TD Format                                                         | 37   |
| 3-12   | HC Mode Changes                                                               | 40   |
| 3-13   | List Service Flowchart                                                        | 41   |
| 3-14   | ED Service Flowchart                                                          | 42   |
| 3-15   | TD Service Flowchart                                                          | 43   |
| 3-16   | Done Queue Operations                                                         | 44   |
| 3-17   | Input-related Legacy Operation Flowchart                                      | 45   |
| 3-18   | Input Emulation Flowchart for USB Keyboard/Mouse                              | 46   |
| 3-19   | Combination of USB Keyboard/Mouse and Legacy Keyboard/Mouse (Input Emulation) | 47   |
| 3-20   | Output-related Legacy Operation Flowchart                                     | 48   |
| 3-21   | Distinctions between Legacy and USB                                           | 49   |
| 5-1    | OpenHCI's PCI Configuration Space                                             | 63   |
| 6-1    | Vo vs. lo (PCI Buffer)                                                        | 80   |
| 6-2    | Vсм (Common Mode Voltage) vs. VDI (Differential Input Sensitivity)            | 82   |
| 7-1    | PCI Clock Waveforms                                                           | 87   |
| 7-2    | PCI Reset Waveforms                                                           | 87   |
| 7-3    | PCI Output Timing                                                             | 88   |
| 7-4    | PCI Input Timing                                                              | 88   |
| 7-5    | PCI Clock Reset                                                               | 88   |
| 7-6    | CRUN vs. GNT                                                                  | 89   |
| 7-7    | USB Device Disconnect Detection                                               | 89   |
| 7-8    | USB Full Speed Device Connect Detection                                       | 89   |
| 7-9    | USB Low Speed Device Connect Detection                                        | 90   |
| 7-10   | USB Signal Rise/Fall Timing                                                   | 90   |
| 7-11   | USB Differential Signal                                                       | 90   |
| 7-12   | USB EOP Signal                                                                | 91   |
| 7-13   | USB Differential Receiver Allowable Jitter Capacitance                        | 91   |

# LIST OF FIGURES (1/2)

| Figure N | No. Title                                 | Page |
|----------|-------------------------------------------|------|
|          |                                           |      |
| 8-1      | Circuit Example of USB Interface Block    | 93   |
| 8-2      | Circuit Example of Legacy Interface Block | 94   |

# LIST OF FIGURES (2/2)

#### LIST OF TABLES

| Table | No. Title                                           | Page |  |
|-------|-----------------------------------------------------|------|--|
| 1-1   | Pin Numbers                                         | 20   |  |
| 2-1   | Pin Table                                           | 21   |  |
| 3-1   | Description of Endpoint Descriptors                 | 34   |  |
| 3-2   | Description of General TD                           | 36   |  |
| 3-3   | Description of Isochronous TD                       | 38   |  |
| 3-4   | Description of Host Controller Communications Area  | 39   |  |
| 3-5   | GateA20 Sequences                                   | 49   |  |
| 4-1   | Device State Transition Conditions                  | 53   |  |
| 4-2   | USB State Transition Conditions                     | 53   |  |
| 4-3   | Mutual Relation between Device State and PCI or USB | 54   |  |
| 4-4   | State Control                                       | 55   |  |
| 5-1   | PCI Configuration Space                             | 59   |  |
| 5-2   | Register Information                                | 60   |  |
| 5-3   | Command Register Information                        | 60   |  |
| 5-4   | Status Register Information                         | 61   |  |
| 5-5   | Base Address (BAR_OHCI) Register Information        | 61   |  |
| 5-6   | I/O Address Register (PC/AT) Information            | 62   |  |
| 5-7   | Power Management Control/Status Information         | 62   |  |
| 5-8   | Host Controller Operational Registers               | 64   |  |
| 5-9   | Legacy Support Registers                            | 64   |  |
| 6-1   | Absolute Maximum Ratings                            | 78   |  |
| 6-2   | Recommended Operating Conditions                    | 78   |  |
| 6-3   | Pin Capacitance                                     | 78   |  |
| 6-4   | DC Characteristics                                  | 79   |  |
| 6-5   | DC Characteristics (PCI Interface Block)            | 79   |  |
| 6-6   | DC Characteristics (USB Interface Block)            | 82   |  |
| 6-7   | DC Characteristics (Control Pin Block)              | 83   |  |
| 6-8   | Power Consumption Characteristics                   | 83   |  |
| 6-9   | System Clock Ratings                                | 83   |  |
| 6-10  | AC Characteristics (PCI Interface Block)            | 84   |  |
| 6-11  | AC Characteristics (USB Interface Block)            | 86   |  |
| 8-1   | Jumper Settings                                     | 94   |  |

[MEMO]

#### **CHAPTER 1 FEATURES**

#### 1.1 Features

#### (1) Functions

- Complies with OpenHCI Specification Release 1.0 and OpenHCI Legacy Support Interface Specification Release Version 1.01.
- Supports asynchronous communication between host CPU and USB devices.
- Supports two types of USB devices: full speed (12 Mbps) devices and low speed (1.5 Mbps) devices.
- System clock: 48 MHz

#### (2) Interface

- USB interface transceiver
- Complies with **Universal Serial Bus Specification Revision 1.0**. Switchable between full speed (12 Mbps) and low speed (1.5 Mbps) modes.
- PCI interface buffer
   Complies with PCI Local Bus Specification Revision 2.1 and PCI Mobile Design Guide Revision 1.0.
   Supports 32-bit, 33-MHz, 5-VPCI/3.3-VPCI operation.

#### (3) Communication with host CPU

- · Communicates via Operational Registers built into USB host controller
- Communicates via the Host Controller Communication Area in the system memory space

#### (4) Memory and I/O space

- Maps to 4-Kbyte space within the 4-Gbyte system memory space.
- 256-byte Host Controller Communication Area is allocated in the system memory space.
- The legacy support register is allocated to 60h/64h in the I/O space.

#### (5) Legacy support

- USB keyboard + USB mouse, USB keyboard + legacy mouse
- Legacy keyboard + USB mouse, legacy keyboard + legacy mouse

#### (6) On-chip FIFO

- PCI side
  - Read: 16 bytes (4  $\times$  4 Dwords), Write: 16 bytes (4  $\times$  4 Dwords)
- USB side

64 bytes (64  $\times$  1 byte)

#### (7) Root Hub

• Equipped with two downstream ports

# (8) Low power consumption

- On-chip clock run function
- On-chip PCI clock stop/USB clock stop functions

#### (9) Others

- CMOS process
- 3-V single power supply

## 1.2 Block Diagram





# 1.3 Pin Configuration



Figure 1-2. Pin Configuration

# 1.4 Pin Configuration Diagram



Figure 1-3. Pin Configuration Diagram

#### 1.5 Pin Names and Pin Numbers

| AD (31:00)<br>CBE (3:0) | : PCI Address and Data<br>: PCI Bus Command and Byte Enable | SMI<br>DP (2:1) | : System Management Interrupt<br>: USB D+ |
|-------------------------|-------------------------------------------------------------|-----------------|-------------------------------------------|
| PAR                     | : PCI Parity                                                | DN (2:1)        | : USB D-                                  |
| FRAME                   | : PCI Cycle Frame                                           | OCI (2:1)       | : Over Current Interrupt                  |
| IRDY                    | : PCI Initiator Ready                                       | PPON (2:1)      | : Port Power ON                           |
| TRDY                    | : PCI Target Ready                                          | SCLK            | : System Clock                            |
| STOP                    | : PCI Stop                                                  | RCVBE           | : USB Receiver and Input Buffer Enable    |
| IDSEL                   | : PCI Initialization Device Select                          | AT              | : AT Mode Enable                          |
| DEVSEL                  | : PCI Device Select                                         | LEGC            | : Legacy Support Enable                   |
| REQ                     | : PCI Request                                               | IRI1            | : IRQ1 Input                              |
| GNT                     | : PCI Grant                                                 | IRI2            | : IRQ12 Input                             |
| PERR                    | : PCI Parity Error                                          | IRO1            | : IRQ1 Output                             |
| SERR                    | : PCI System Error                                          | IRO2            | : IRQ12 Output                            |
| INTA                    | : PCI Interrupt                                             | A20S            | : GateA20 State                           |
| PCLK                    | : PCI Clock                                                 | WAKE            | : Wakeup Interrupt                        |
| RST                     | : PCI Reset                                                 | TEST (3:1)      | : TEST Control                            |
| CRUN                    | : PCI Clock running                                         | TMN (7:1)       | : TEST signal                             |
|                         |                                                             |                 |                                           |

#### Table 1-1. Pin Numbers

| Pin Number | Pin Name |
|------------|----------|------------|----------|------------|----------|------------|----------|
| 1          | Vdd      | 26         | GND      | 51         | Vdd      | 76         | GND      |
| 2          | AD23     | 27         | AD13     | 52         | DP1      | 77         | PCLK     |
| 3          | AD22     | 28         | AD12     | 53         | DN1      | 78         | Vdd      |
| 4          | AD21     | 29         | AD11     | 54         | OCI1     | 79         | AT       |
| 5          | AD20     | 30         | AD10     | 55         | PPON1    | 80         | IRO1     |
| 6          | AD19     | 31         | AD09     | 56         | DP2      | 81         | IRO2     |
| 7          | GND      | 32         | Vdd      | 57         | DN2      | 82         | A20S     |
| 8          | AD18     | 33         | AD08     | 58         | OCI2     | 83         | GND      |
| 9          | AD17     | 34         | CBE0     | 59         | PPON2    | 84         | INTA     |
| 10         | AD16     | 35         | AD07     | 60         | TMN5     | 85         | RST      |
| 11         | CBE2     | 36         | AD06     | 61         | TMN4     | 86         | GNT      |
| 12         | FRAME    | 37         | AD05     | 62         | TMN3     | 87         | REQ      |
| 13         | Vdd      | 38         | GND      | 63         | GND      | 88         | GND      |
| 14         | IRDY     | 39         | AD04     | 64         | TMN2     | 89         | AD31     |
| 15         | TRDY     | 40         | AD03     | 65         | TEST3    | 90         | AD30     |
| 16         | DEVSEL   | 41         | AD02     | 66         | TEST2    | 91         | AD29     |
| 17         | STOP     | 42         | AD01     | 67         | TEST1    | 92         | AD28     |
| 18         | PERR     | 43         | AD00     | 68         | WAKE     | 93         | AD27     |
| 19         | GND      | 44         | GND      | 69         | TMN1     | 94         | Vdd      |
| 20         | SERR     | 45         | CRUN     | 70         | SMI      | 95         | AD26     |
| 21         | PAR      | 46         | TMN7     | 71         | IRI1     | 96         | AD25     |
| 22         | CBE1     | 47         | TMN6     | 72         | IRI2     | 97         | AD24     |
| 23         | AD15     | 48         | Vdd      | 73         | RCVBE    | 98         | CBE3     |
| 24         | AD14     | 49         | SCLK     | 74         | LEGC     | 99         | IDSEL    |
| 25         | Vdd      | 50         | GND      | 75         | Vdd      | 100        | GND      |

#### 2.1 Pin Table

#### Table 2-1. Pin Table

| Pin Name     | I/O     | Buffer Type                                                     | Active Level | Function                                           |
|--------------|---------|-----------------------------------------------------------------|--------------|----------------------------------------------------|
| AD (31 : 0)  | I/O     | 5 V PCI I/O                                                     |              | PCI "AD [31 : 0]" signal                           |
| CBE (3:0)    | I/O     | 5 V PCI I/O                                                     |              | PCI "C/BE [3 : 0]" signal                          |
| PAR          | I/O     | 5 V PCI I/O                                                     |              | PCI "PAR" signal                                   |
| FRAME        | I/O     | 5 V PCI I/O                                                     |              | PCI "FRAME#" signal                                |
| IRDY         | I/O     | 5 V PCI I/O                                                     |              | PCI "IRDY#" signal                                 |
| TRDY         | I/O     | 5 V PCI I/O                                                     |              | PCI "TRDY#" signal                                 |
| STOP         | I/O     | 5 V PCI I/O                                                     |              | PCI "STOP#" signal                                 |
| IDSEL        | I       | 5 V PCI Input                                                   |              | PCI "IDSEL" signal                                 |
| DEVSEL       | I/O     | 5 V PCI I/O                                                     |              | PCI "DEVSEL#" signal                               |
| REQ          | 0       | 5 V PCI Output                                                  |              | PCI "REQ#" signal                                  |
| GNT          | I       | 5 V PCI Input                                                   |              | PCI "GNT#" signal                                  |
| PERR         | I/O     | 5 V PCI I/O                                                     |              | PCI "PERR#" signal                                 |
| SERR         | 0       | 5 V PCI N-ch Open Drain                                         |              | PCI "SERR#" signal                                 |
| INTA         | 0       | 5 V PCI N-ch Open Drain                                         | Low          | PCI "INTA#" signal                                 |
| PCLK         | I       | 5 V PCI Input                                                   |              | PCI "CLK" signal                                   |
| RST          | I       | 5 V Schmitt Input                                               | Low          | PCI "RST#" signal                                  |
| CRUN         | I/O     | 5 V PCI I/O (N-ch Open Drain)                                   |              | PCI "CLKRUN#" signal                               |
| SCLK         | I       | 5 V Schmitt Input                                               |              | System clock input                                 |
| SMI          | 0       | 5 V IoL = 12 mA N-ch Open Drain Low                             |              | System management interrupt output                 |
| DP (2 : 1)   | I/O     | USB D+I/O                                                       |              | USB's D+ signal                                    |
| DN (2 : 1)   | I/O     | USB D–I/O                                                       |              | USB's D– signal                                    |
| OCI (2 : 1)  | I (I/O) | 5 V Input with excessive through<br>current prevention function | High         | USB Root Hub Port's overcurrent status input       |
| PPON (2 : 1) | 0       | 5 V IoL = 6 mA Output                                           | High         | USB Root Hub Port's power supply control<br>output |
| RCVBE        | I       | 5 V Input                                                       | High         | USB Receiver and Input Buffer Enable signal        |
| AT           | I (I/O) | 5 V Schmitt Input                                               | High         | Legacy support switch                              |
| LEGC         | l (I/O) | 5 V Schmitt Input                                               | High         | Legacy support switch                              |
| IRI1         | I (I/O) | 5 V Input with excessive through<br>current prevention function | High         | INT input from keyboard                            |
| IRI2         | I (I/O) | 5 V Input with excessive through<br>current prevention function | High         | INT input from mouse                               |
| IRO1         | 0       | 5 V Io∟ = 6 mA N-ch Open Drain                                  | High         | INT output from keyboard                           |
| IRO2         | O (I/O) | 5 V Io∟ = 6 mA N-ch Open Drain                                  | High         | INT output from mouse                              |
| A20S         | O (I/O) | 5 V Io∟= 6 mA N-ch Open Drain                                   | -            | GateA20 State output                               |
| WAKE         | 0       | 5 V lo∟ = 6 mA Output                                           | High         | Wakeup interrupt output                            |
| TEST (3 : 1) | I       | 3 V Input with 50 k $\Omega$ Pull up R                          | -            | Test pin                                           |
| TMN (7 : 1)  | I/O     | 3 V I/O with 50 kΩ Pull up R                                    |              | Test pin                                           |

- **Remarks 1.** The 5-V buffer in the table indicates a 5-V tolerant buffer. "5-V tolerant" means that the buffer is a 3-V buffer with 5-V maximum voltage.
  - 2. "5 V PCI" indicates a PCI buffer that has a 5-V maximum voltage circuit which complies with the 3-V PCI standard. It does not indicate a buffer that fully complies with the 5-V PCI standard. However, this function can be used for evaluating the operation of a device by attaching a 5-V add-in card beforehand.
  - **3.** The signals marked as "(I/O)" in the above table operate as I/O signals during testing. However, they do not need to be considered in normal use situations.

#### 2.2 Description of Pin Functions

#### • Power supply

| Pin | Pin No.                                    | Direction | Function          |
|-----|--------------------------------------------|-----------|-------------------|
| Vdd | 1, 13, 25, 32, 48, 51, 75, 78, 94          | -         | +3 V power supply |
| GND | 7, 19, 26, 38, 44, 50, 63, 76, 83, 88, 100 | -         | Ground            |

#### • PCI interface

| Pin          | Pin No.                                                                          | Direction | Function                  |
|--------------|----------------------------------------------------------------------------------|-----------|---------------------------|
| AD (31 : 00) | 2 to 6, 8 to 10, 23, 24, 27 to 31, 33,<br>35 to 37, 39 to 43, 89 to 93, 95 to 97 | I/O       | PCI "AD [31 : 00]" signal |
| CBE (3:0)    | 11, 22, 34, 98                                                                   | I/O       | PCI "C/BE [3 : 0]" signal |
| PAR          | 21                                                                               | I/O       | PCI "PAR" signal          |
| FRAME        | 12                                                                               | I/O       | PCI "FRAME#" signal       |
| IRDY         | 14                                                                               | I/O       | PCI "IRDY#" signal        |
| TRDY         | 15                                                                               | I/O       | PCI "TRDY#" signal        |
| STOP         | 17                                                                               | I/O       | PCI "STOP#" signal        |
| IDSEL        | 99                                                                               | I         | PCI "IDSEL" signal        |
| DEVSEL       | 16                                                                               | I/O       | PCI "DEVSEL#" signal      |
| REQ          | 87                                                                               | 0         | PCI "REQ#" signal         |
| GNT          | 86                                                                               | I         | PCI "GNT#" signal         |
| PERR         | 18                                                                               | I/O       | PCI "PERR#" signal        |
| SERR         | 20                                                                               | 0         | PCI "SERR#" signal        |
| INTA         | 84                                                                               | 0         | PCI "INTA#" signal        |
| PCLK         | 77                                                                               | I         | PCI "CLK" signal          |
| RST          | 85                                                                               | I         | PCI "RST#" signal         |
| CRUN         | 45                                                                               | I/O       | PCI "CLKRUN#" signal      |

Remark For details of PCI operations, see the PCI Local Bus Specification Revision 2.1.

# System clock

| Pin  | Pin No. | Direction | Caution                                         |
|------|---------|-----------|-------------------------------------------------|
| SCLK | 49      | I         | System clock input<br>Apply 48-MHz clock input. |

#### • Test pins

| Pin          | Pin No.                    | Direction | Caution                                 |
|--------------|----------------------------|-----------|-----------------------------------------|
| TEST (3 : 1) | 65, 66, 67                 | I         | Be sure to leave open on circuit board. |
| TMN (7 : 1)  | 46, 47, 60, 61, 62, 64, 69 | I/O       | Be sure to leave open on circuit board. |

#### • System interface

| Pin   | Pin No. | Direction | Function                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|---------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SMI   | 70      | 0         | <ul><li>System management interrupt output</li><li>Changed to INTA by ownership change before being output.</li><li>0: Interrupt occurs</li><li>1: Interrupt does not occur</li></ul>                                                                                                                                                                                                       |
| RCVBE | 73      | I         | <ul> <li>USB Receiver/Input Buffer Enable signal</li> <li>0: Excessive through current prevention/differential buffer operating current cut-off function ON</li> <li>1: Excessive through current prevention/differential buffer operating current cut-off function OFF</li> <li>The pins being controlled are as follows.</li> <li>DP (2: 1), DN (2: 1), OCI (2: 1), IRI1, IRI2</li> </ul> |
| WAKE  | 68      | 0         | Wakeup request signal is output from the USB.<br>0: No Wakeup request<br>1: Wakeup request exists                                                                                                                                                                                                                                                                                           |

#### • USB interface

| Pin          | Pin No. | Direction | Function                                                                                                                          |
|--------------|---------|-----------|-----------------------------------------------------------------------------------------------------------------------------------|
| DP (2 : 1)   | 52, 56  | I/O       | USB's D+ signal<br>Shared with DNx pins having the same numbers.                                                                  |
| DN (2 : 1)   | 53, 57  | I/O       | USB's D- signal<br>Shared with DPx pins having the same numbers.                                                                  |
| OCI (2 : 1)  | 54, 58  | I         | Pin for inputting the overcurrent status of the USB Root<br>Hub Port<br>0: No power supply problem<br>1: Overcurrent has occurred |
| PPON (2 : 1) | 55, 59  | 0         | Power supply control output for USB Root Hub Port<br>0: Power supply OFF<br>1: Power supply ON                                    |

| Pin                  | Pin No. | Direction | Function                                                                                                                            |
|----------------------|---------|-----------|-------------------------------------------------------------------------------------------------------------------------------------|
| AT                   | 79      | 1         | Legacy support<br>0: Legacy OFF<br>1: Legacy ON                                                                                     |
| LEGC                 | 74      | I         | Legacy support switch<br>0: Legacy OFF<br>1: Legacy ON<br>When off, "L" clamp IRI1 and IRI2 and leave IRO1,<br>IRO2, and A20S open. |
| IRI1 <sup>Note</sup> | 71      | I         | INT input from keyboard: active H                                                                                                   |
| IRI2 <sup>Note</sup> | 72      | I         | INT input from mouse: active H                                                                                                      |
| IRO1                 | 80      | 0         | INT output from keyboard: active H                                                                                                  |
| IRO2                 | 81      | 0         | INT output from mouse: active H                                                                                                     |
| A20S                 | 82      | 0         | GateA20 State output                                                                                                                |

#### • Legacy support interface

**Note** IRQ is sampled using the 12-MHz clock signal generated by SCLK, and an interrupt is detected as a result. The next IRQ is not received during emulation. After emulation is completed, an interrupt can be received once the IRQ's H level has been sampled.

#### 2.3 Handling Unused Pins

Handle unused pins as shown below.

| Pin          | Direction | Connection Method                                 |
|--------------|-----------|---------------------------------------------------|
| DPx          | I/O       | Connect via 15 k $\Omega$ ±5% pull-down resistor. |
| DNx          | I/O       | Connect via 15 k $\Omega$ ±5% pull-down resistor. |
| OCIx         | I         | "L" clamp                                         |
| PPONx        | 0         | No Connection (Open)                              |
| TEST (3 : 1) | I         | No Connection (Open)                              |
| TMN (1 : 7)  | I/O       | No Connection (Open)                              |

When the legacy function is off (AT = L, LEGC = L), handle unused pins as shown below.

| Pin  | Direction | Connection Method    |
|------|-----------|----------------------|
| IRI1 | I         | "L" clamp            |
| IRI2 | I         | "L" clamp            |
| IRO1 | 0         | No Connection (Open) |
| IRO2 | 0         | No Connection (Open) |
| A20S | 0         | No Connection (Open) |

#### CHAPTER 3 DESCRIPTION OF USB HOST CONTROLLER FUNCTIONS

This chapter provides an overview of the USB, the operations of the host controller, and the structure of the interface data that is used. For details, see the **Open Host Controller Interface Specification Release 1.0** and **OpenHCI Legacy Support Interface Specification Release Version 1.01**.

#### 3.1 Overview of USB

The USB (Universal Serial Bus) is a type of serial bus that enables transfer of data between a host computer and various types of peripheral devices. The USB host has point-to-point connections with USB devices via a tiered star topology, in which each star contains a device called a hub. Figure 3-1 shows a USB bus topology. The USB enables connection of up to 127 devices via this tiered star topology. In addition, devices can be connected or disconnected while the system is still operating.



Figure 3-1. Bus Topology

USB signals are transferred point-to-point as differential signals using two signal lines. There are two signal trace modes: full speed mode (12 Mbs) and low speed mode (1.5 Mbs). Low speed mode is used in low-cost devices such as mouse devices that do not require much EMI protection. As shown in Figures 3-2 and 3-3, the mode is set as full speed or low speed based on the position of the terminating resistors connected to both ends of the USB cable. Terminating resistors are also used at each port to detect when devices are being connected or disconnected.



Figure 3-2. Full Speed Device Cable and Resistor Connections





The host schedules and manages data transfers. Consequently, transfers must always be started by the host, and all transfers are performed using up to three packets (token, data, and handshake packets). The token packet sends USB devices information on the processing direction, type of transaction, address, endpoint, etc. The USB device decodes the address field and determines whether or not it has been accessed. The data packet contains the data that is sent in the direction (from host to device or from device to host) that is specified by the token packet. The handshake packet is returned to the source of the transfer to indicate whether or not the transfer was successful. The following four types of transfers occur between USB hosts and USB devices.

- Interrupt transfer
   This is a small data transfer which is used to send information from a USB device to client software. The HCD (Host Controller Driver) sends a token packet to a device within the period required by the device, after which the USB data transfer is executed.
- Isochronous transfer This is a periodic data transfer that uses a constant data transfer rate.
- Control transfer
   This is a non-periodic data transfer that is used to send information about configuration, commands, and status between the client software and a USB device.
- Bulk transfer
   This is a non-periodic data transfer that is used to send large amounts of information
   between the client software and a USB device.

Under OpenHCI, data transfers are divided into two categories: periodic and non-periodic. Periodic transfers, which are executed within a specified period, are further divided into the interrupt and isochronous transfer types. Non-periodic transfers, which are not executed periodically, are divided into control and bulk transfer types.

To implement the following types of operations, a device called a USB host controller and software called the USB HCD must both be installed on the host computer. OpenHCI is the specifications that apply to the relation between the host controller and the HCD software. This device complies with the **Open HCI Specification Release 1.0** and **OpenHCI Legacy Support Interface Specification Release Version 1.01**.

#### 3.2 Host Controller's Communication Method

The host controller (HC) and the host controller driver (HCD) communicate via the following two paths.

- Operational registers
- Host Controller Communications Area (HCCA)

In communication that uses the operational registers which are built into the HC, the HC is the PCI target device. The operational registers are a set of registers that include control bits, status bits, list pointers, etc. They also include pointers that indicate the position of the HCCA (Host Controller Communications Area) within system memory. The HC becomes the PCI bus master for communications that are executed via the HCCA. The HCCA is a 256-byte system memory area that contains head pointers to the interrupt ED list, head pointers to the Done Queue, and frame-related status information. The software uses this system memory to directly control the HC's functions without reading from the HC, as long as operation conditions are normal (i.e., there are no errors). These two paths are used for handling HC control tasks and USB data transfer results.

The HCD executes communication between the HC and USB devices, based on the enqueued ED (Endpoint Descriptor) and TD (Transfer Descriptor). An ED contains information (maximum packet size, endpoint address, endpoint speed and data flow direction) that the HC requires to communicate with the endpoint, and the ED can also be used as the TD queue's anchor. The HCD generates EDs and assigns them to the various endpoints, when are then listed and linked.

A TD contains information (data toggle information, buffer positions in system memory, and complete status code) that is required for the data packet to be sent. Each TD also contains information (data buffer size ranging from 0 to 8192 bytes, with a maximum of 1024-byte transfer per data packet) that is related to at least one data packet. Enqueued TDs are serviced in FIFO order. The TD queue is linked with a certain endpoint's ED and the TDs are linked with the TD queue. The HCD generates data from this structure and passes the data to the HC for processing.

Figure 3-4 shows the relation between EDs and TDs.





ED lists are categorized into four types: bulk, control, interrupt, and isochronous. Three types of head pointers of ED list are held (one for each of the above types except isochronous). The isochronous ED list is simply linked following the interrupt ED. The head pointers to the bulk and control ED lists are held in the operational registers, while the head pointers to the interrupt ED list are held in the HCCA. There are 32 interrupt head pointers, and the head pointer that is used by a frame is determined based on the usage of the frame counter's low-order 5 bits (indicating the addresses of the 32 types). The interrupt ED list structure is a tree structure, as is shown in Figure 3-5, in which the execution interval is determined according to the depth of the points where several paths intersect. In other words, interrupt EDs that are linked to the root of the tree structure are allocated and executed at a rate of 1 ms per ED.



#### Figure 3-5. Interrupt ED List

Figure 3-6 shows how the OpenHCI's bandwidth is allocated. The HC selects the list to be serviced based on a prioritization algorithm. Control and bulk lists take priority from the start of the frame to the point where HcFmRemaining becomes HcPeriodicStart.

When HcFmRemaining becomes HcPeriodicStart, periodic list servicing takes priority. The priority of periodic list servicing is higher than that of control or bulk servicing up until the point where periodic list servicing is completed or the frame period is completed. After periodic list servicing is completed, control or bulk list servicing is resumed.





Time

Interrupt/isochronous list servicing begins with servicing the interrupt ED head pointer that is serviced for the current frame. Since isochronous lists are attached after interrupt lists, interrupt lists must have a higher priority than isochronous lists. Bulk and control list servicing resumes at the point in each list where servicing was interrupted. When servicing reaches the end of the list, a value is loaded from the head pointer and servicing continues. The control endpoint is given access privileges that are at least equivalent to those of the bulk endpoint, and this service ratio is determined by ControlBulkServiceRatio in HcControl. Figure 3-7 shows an example where the control/bulk service ratio is 4:1. When control and bulk take priority, the HC executes ED servicing of each list according to the ControlBulkServiceRatio.

Figure 3-7. When Control/Bulk Service Ratio Is 4:1



This control/bulk service ratio is retained over several frames. As soon as the HC services the data packet for one of the TDs included in an ED, it begins servicing the next ED.

#### 3.3 Endpoint Descriptor

An ED is always allocated in 16-byte units to system memory. When the ED list is referenced, if it contains a TD that is linked to an ED, the HC executes the transfer specified by that TD. If the HCD must change the head pointer (HeadP) value, list servicing for all EDs that have the same transfer type as the ED to be deleted must be rendered invalid so as to prevent the HC from accessing the EDs. Therefore, the HCD sets a Skip bit.

#### 3.3.1 Endpoint descriptor format

#### Figure 3-8. Endpoint Descriptor Format

| ;                                 | 2   | 1               | 1 | 1                                                     | 1                                                                   | 1 1                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------|-----|-----------------|---|-------------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                   | 6   | 6               | 5 | 4                                                     | 3                                                                   | 2 1                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| -                                 | MPS |                 | F | Κ                                                     | S                                                                   | D                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | EN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TD Queue Tail Pointer (TailP)     |     |                 |   |                                                       |                                                                     |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TD Queue Head Pointer (HeadP)     |     |                 |   |                                                       |                                                                     |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | С                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Н                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Next Endpoint Descriptor (NextED) |     |                 |   |                                                       |                                                                     |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| \$                                | _   | TD Qu<br>TD Que |   | MPS     F     TD Queue Tail Poi     TD Queue Head Poi | MPS     F     K     TD Queue Tail Pointer     TD Queue Head Pointer | 2         1         1         1         1         1           6         6         5         4         3           -         MPS         F         K         S           TD Queue Tail Pointer (Ta         TD Queue Head Pointer (Head Pointer)         TH | 2         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1 | 2       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 | 2         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1 | 2         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1 | 2       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 | 2       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 | 2       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 | 2       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 | 2       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 | 2       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 |

#### 3.3.2 Endpoint descriptor field definitions

| Table 3-1. | Description of | f Endpoint Descriptors |
|------------|----------------|------------------------|
|------------|----------------|------------------------|

| Name   | HC Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FA     | R         | Function Address<br>USB address of function that includes the endpoint that is controlled by this ED                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| EN     | R         | Endpoint Number<br>Endpoint address in function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| D      | R         | Direction         Indicates the data flow direction (IN or OUT). If neither IN nor OUT are specified, the transfer direction is defined by the TD's PID (Packet ID) field.         Code       Direction         00b       Get direction From TD         01b       OUT         10b       IN         11b       Get direction From TD                                                                                                                                                                                                                    |
| S      | R         | Speed<br>This indicates the endpoint's speed.<br>• full-speed (S = 0)<br>• low-speed (S = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| К      | R         | Skip<br>When this bit is set, the HC proceeds to the next ED without accessing the TD queue or issuing<br>a USB token to the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                |
| F      | R         | Format<br>This indicates the format of a TD that is linked to this ED. For control, bulk, or interrupt<br>endpoints, if $F = 0$ , then the General TD format is used. For isochronous endpoints, if $F = 1$ , the<br>Isochronous TD format is used.                                                                                                                                                                                                                                                                                                   |
| MPS    | R         | Maximum Packet Size<br>This field indicates the maximum number of bytes (1024 bytes) per data packet that can be<br>received from the endpoint or sent to an endpoint. When a write operation (OUT or SETUP) is<br>executed from the HC to the endpoint, the size of the data packet to be sent always becomes<br>either the Maximum Packet Size or the size of the data in the buffer, whichever is smaller.<br>When a read operation (IN) is executed from the endpoint to the HC, the data packet size is<br>determined according to the endpoint. |
| TailP  | R         | TD Queue Tail Pointer<br>When TailP and HeadP have the same value, the list does not contain any TDs that can be<br>serviced by the HC. When the TailP and HeadP values are different, the list contains TDs.                                                                                                                                                                                                                                                                                                                                         |
| Н      | R/W       | Halted<br>This bit is set by the HC to indicate when servicing of the endpoint TD queue has been<br>suspended due to a normal TD servicing error.                                                                                                                                                                                                                                                                                                                                                                                                     |
| С      | R/W       | toggle Carry<br>This bit is the data toggle carry bit. When a TD is retired, the final data toggle value (LSb in the<br>data Toggle field) that was used by the retired TD is written. This field cannot be used by<br>isochronous endpoints.                                                                                                                                                                                                                                                                                                         |
| HeadP  | R/W       | TD Queue Head Pointer<br>This indicates the next TD to be serviced at this endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| NextED | R         | Next ED<br>When its value is other than zero, this bit indicates the next ED.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

#### 3.4 Transfer Descriptors

TDs (Transfer Descriptors) are used by the HC to indicate the buffer for the data that is sent to or from an endpoint. TDs are divided into two types: General TDs and Isochronous TDs. General TDs are used by interrupt, control, and bulk endpoints while Isochronous TDs are used for handling isochronous transfers.

For both General and Isochronous TDs, buffers ranging from 0 bytes to 8,192 bytes can be indicated. Also, the data buffer described by one TD can be divided into two pages. This enables the elimination of various problems, such as problems related to forced physical connection of buffers or transfer of surplus data.

When the HCD appends a TD, the TD indicated by TailP is linked to the new TD, and TailP is then changed to indicate the appended TD. Therefore, the appended TD is always added to the end of the TD queue. The HC services the TD asynchronously in relation to servicing performed by the host processor. Consequently, when it is necessary to switch from the TD queue to something else, the HC's endpoint TD queue servicing must be suspended to avoid problems from occurring due to this switch. Suspension of TD servicing is achieved when the HCD sets the Skip bit in the ED to be deleted.

#### 3.4.1 General transfer descriptor format

General TDs are used for control, bulk, or interrupt transfers, and they must always be allocated in 16-byte units to system memory.

|         | 3<br>1 | 2<br>8                       | 27 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>1 | 2 1<br>0 9 | 1<br>8 |   | 0<br>3 | 0<br>0 |
|---------|--------|------------------------------|----|--------|--------|--------|--------|--------|------------|--------|---|--------|--------|
| Dword 0 |        | СС                           | E  | С      | Т      | -      |        | DI     | DP         | R      | _ |        |        |
| Dword 1 |        | Current Buffer Pointer (CBP) |    |        |        |        |        |        |            |        |   |        |        |
| Dword 2 |        | Next TD (NextTD) 0           |    |        |        |        |        |        |            |        | ) |        |        |
| Dword 3 |        | Buffer End (BE)              |    |        |        |        |        |        |            |        |   |        |        |

#### Figure 3-9. General TD Format

#### 3.4.2 General transfer descriptor field definitions

#### Table 3-2. Description of General TD

| Name   | HC Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| R      | R         | buffer Rounding<br>When this bit's value is "0", the data buffer defined by the last data packet sent from the endpoint<br>specified by the TD must be a completely full buffer. When its value is "1", the data buffer<br>defined by the last data packet is not full, even if there are no errors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| DP     | R         | Direction/PID         This indicates the data flow direction and PID used by a token. This field only has significance in relation to the HC when 00b or 11b is set to indicate that the ED's D field has delayed the PID judgment until the TD.         Image: Code state of the text of the text of tex of text of text of tex of text of text of text of text of tex of |  |  |  |  |  |  |  |  |
| DI     | R         | Delay Interrupt<br>This indicates the time until a interrupt occurs as notification of completed TD servicing. When<br>the TD has been completed, the HC delays the interrupt event until the frame indicated by this<br>bit. When this bit's value is 111b, interrupts related to completion of this TD do not occur.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| т      | R/W       | Data Toggle<br>This field is used to generate a comparison or occurrence of data PID values (DATA0 or<br>DATA1). This field is updated after each successful transfer of a data packet. When the data<br>Toggle field's Msb is "0", the data Toggle field's Lsb, which was acquired from the ED's toggle<br>Carry bit, is ignored. When data Toggle field's Msb is "1", the data Toggle field's LSb indicates<br>the data toggle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
| EC     | R/W       | Error Count<br>This field is incremented after each transmission error. If an error occurs after the Error Count<br>has reached "2", the type of error is written to the Condition Code field and is transferred to the<br>done queue. If servicing ends without any errors, the Error Count is reset to "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
| СС     | R/W       | Condition Code<br>This field is updated each time processing is executed, regardless of whether or not the<br>processing was successful. If it was successful, this field is set as NoERROR. If unsuccessful, it<br>is set according to the type of error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| СВР    | R/W       | Current Buffer Pointer<br>This includes the next physical address in memory that will be accessed by a transfer from or to<br>an endpoint.<br>A "0" value indicates either that the data packet has zero length or that all bytes have been<br>transferred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
| NextTD | R/W       | Next TD<br>This specifies the next TD in the TD list linked to the endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| BE     | R         | Buffer End<br>This indicates the physical address of the last byte in the TD's buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |

The General TD's Current Buffer Pointer indicates the data buffer address used for a data packet transfer to or from an endpoint. If the transfer is completed without the occurrence of any kind of error, the HC advances the Current Buffer Pointer by exactly the number of transferred bytes. If the buffer address indicated by the Current Buffer Pointer exceeds the 4-K boundary during a data packet transfer, the high-order 20 bits of the Buffer End field is copied to the working value from the Current Buffer Pointer. The next buffer address becomes byte 0 in the same 4-K page space that is used when the final byte is retained.





#### 3.4.3 Isochronous transfer descriptor format

Isochronous TDs are used only by isochronous endpoints. All TDs linked to the ED must use this format when F = 1. This TD is allocated to system memory in 32-byte units.

|         | 3               | 2 | 2 | 2 2     | 2 2  | 2       | 2    |   | 1 | 1 | 1 |   | 0            | 0 |  | 0 |
|---------|-----------------|---|---|---------|------|---------|------|---|---|---|---|---|--------------|---|--|---|
|         | 1               | 8 | 7 | 6 4     | 13   | 1       | 0    |   | 6 | 5 | 2 | 1 | 5            | 4 |  | 0 |
| Dword 0 | CC              |   | - | FC      |      | DI      |      | - |   |   |   |   | SF           |   |  |   |
| Dword 1 |                 |   |   | Buffe   | Pa   | ge 0 (E | 3P0) |   |   |   |   |   | -            |   |  |   |
| Dword 2 | NextTD 0        |   |   |         |      |         |      |   |   |   |   |   |              |   |  |   |
| Dword 3 | Buffer End (BE) |   |   |         |      |         |      |   |   |   |   |   |              |   |  |   |
| Dword 4 |                 |   |   | Offset1 | /PS\ | N1      |      |   |   |   |   |   | Offset0/PSW0 |   |  |   |
| Dword 5 |                 |   |   | Offset3 | /PS\ | N3      |      |   |   |   |   |   | Offset2/PSW2 |   |  |   |
| Dword 6 |                 |   |   | Offset5 | /PS\ | N5      |      |   |   |   |   |   | Offset4/PSW4 |   |  |   |
| Dword 7 |                 |   |   | Offset7 | /PS\ | N7      |      |   |   |   |   |   | Offset6/PSW6 |   |  |   |

#### Figure 3-11. Isochronous TD Format

#### 3.4.4 Isochronous transfer descriptor field definitions

| Name    | HC Access | Description                                                                                                                                                                                        |
|---------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SF      | R         | Starting Frame<br>This includes the low-order 16 bits of the number of frames sent by the Isochronous TD's first<br>data packet.                                                                   |
| DI      | R         | Delay Interrupt<br>This indicates the time until a interrupt occurs following completion of Isochronous TD servicing.                                                                              |
| FC      | R         | Frame Count<br>This is the number of data packets indicated by the Isochronous TD. When Frame Count = 0,<br>one data packet is included and when Frame Count = 7, eight data packets are included. |
| СС      | R/W       | Condition Code<br>This field includes a completion code when an Isochronous TD has been transferred to the Done<br>Queue.                                                                          |
| BP0     | R         | Buffer Page 0<br>This is the physical page number of the first byte in the data buffer used by the Isochronous TD.                                                                                 |
| NextTD  | R/W       | Next TD<br>This indicates the next Isochronous TD in the Isochronous TD queue linked to an ED.                                                                                                     |
| BE      | R         | Buffer End<br>This includes the physical address of the buffer's last byte.                                                                                                                        |
| OffsetN | R         | Offset<br>This is used to determine the size and start address of an isochronous data packet.                                                                                                      |
| PSWN    | W         | Packet Status Word<br>This includes the size of the completion code and the received isochronous data packet.                                                                                      |

Table 3-3. Description of Isochronous TD

Isochronous TDs have a (Frame Count + 1) frame buffer with a continuous range from 1 to 8. The first data packet is sent when the low-order 16 bits of HcFmNumber matches the Isochronous TD's Starting Frame value. If the buffer address exceeds the 4-K boundary during a data packet transfer, the high-order 20 bits of the Buffer End field is used as the physical address of the next page. Consequently, the next buffer address becomes byte 0 in the same 4-K page space that is used when the final byte is retained.

#### 3.5 Host Controller Communications Area

The HCCA (Host Controller Communications Area) is a 256-byte area in system memory that is used by the system software for sending and receiving control/status information to and from the HC. The system software always writes the address of the area to the HC's HcHCCA field.

#### 3.5.1 Host controller communications area format

| Offset | Size<br>(bytes) | Name               | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-----------------|--------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 128             | HccaInterruptTable | R   | This 32-Dword entry table is a pointer to ED interrupt lists.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0×80   | 2               | HccaFrameNumber    | W   | This includes the current frame number. This value is updated by the HC before periodic list servicing of the frame begins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0×82   | 2               | HccaPad1           | W   | When the HC updates the HccaFrameNumber value, the HC sets "0" to this word.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0×84   | 4               | HccaDoneHead       | W   | When the HC reaches the end of a frame and a decremented value<br>of "0" is shown as the Delay Interrupt value, the HC writes the<br>current HcDoneHead value to this field. At this point, interrupts<br>occur as valid interrupts. The HC does not write again until the<br>software clears the WD bit in the HcInterruptStatus register. If this<br>field has a value of "0", interrupts can occur for reasons other than<br>updating of HccaDoneHead, and the HcInterruptStatus register<br>must be accessed to determine the cause of the interrupt. If this<br>field's value is not "0", the interrupt is due to updating of the Done<br>Queue. If this field's LSb is not "0", another interrupt event has<br>occurred. The HcInterruptStatus field must be checked to<br>determine the cause of that interrupt. |
| 0×88   | 116             | reserved           | R/W | This field is reserved for use by the HC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### Table 3-4. Description of Host Controller Communications Area

#### 3.5.2 Host controller communications area description

HccaInterruptTable is a 32-Dword entry table which functions as a pointer to the ED list's various interrupt lists. The more of these lists that an ED is linked to, the higher the execution rate. The execution rate is 32 ms for an ED that is in only one list, but it is 6 ms for an ED that is in two lists. An ED that is linked to all 32 lists is executed at a rate of once per frame. The last entry in each of the 32 interrupt lists must specify an isochronous list.

After an SOF (Start Of Frame) token is sent, the HC overwrites HccaFrameNumber using the FrameNumber value from HcFmNumber before it starting reading the ED to be serviced in a new frame.

### 3.6 HC Mode Changes

HostControllerFunctionalState indicates which of the four states (modes) the HC is in: USBOPERATIONAL, USBRESET, USBSUSPEND, and USBRESUME. The HCD can change USB modes only as shown in Figure 3-12 and the HC can execute only one change: from USBSUSPEND to USBRESUME during a remote wakeup event.



Figure 3-12. HC Mode Changes

When in USBOPERATIONAL mode, the HC services lists and issues an SOF token. FrameInterval is loaded to FrameRemaining at the same time as the mode is being changed to USBOPERATIONAL.

The first SOF token to be sent after changing to UsbOPERATIONAL mode is sent at the frame boundary when changing from FrameRemaining (value: "0") to FrameInterval. At UsbRESET, the HC forcibly sends a reset signal to the bus. After a hardware reset, the HC always changes to UsbRESET mode. When in UsbSUSPEND mode, the USB is temporarily stopped. When in this mode, the HC monitors the USB wakeup operations. The HC can forcibly change to UsbRESUME mode according to the remote wakeup condition. This change may conflict with the change to UsbRESET mode that is performed by the HCD. When such a conflict has occurred, the HCD's change to UsbRESET mode takes priority. A change to UsbRESUME mode is not possible during the first 5 ms following a change to UsbRESUME mode, the HC forcibly sends a resume signal to the bus. While in UsbRESUME mode, the root hub always passes a USB resume signal to downstream ports. The change to UsbRESUME is started by a remote wakeup signal sent by the HCD or the root hub.

#### 3.7 List Service Flow

Figure 3-13 shows a list service flowchart. After the HC determines which list to service, list servicing is executed via this list service flow pattern. Since lists are periodically rendered invalid by the HCD due to ED switching (or other reasons), the HC must first check whether or not the target list is valid by checking each list enable bit in HcControl when servicing the list.

#### Figure 3-13. List Service Flowchart



If the checked list is valid, the HC services the list. If it is invalid, the HC skips that list and proceeds to the next list. When a list is valid, the HC checks the position of the first ED for which servicing is requested. During periodic list servicing, if the head pointer value is "0", it means there are no EDs in the list and the HC proceeds to the next list. By contrast, during non-periodic list servicing, if the "CurrentED" value in each list is "0", the HC checks each "ListFilled" value. If it finds that the "ListFilled" value has been set to "1", it means that there is at least one ED in the target list that requires servicing. In such cases, the HC copies the "HeadED" value to "CurrentED" and clears the "Filled" bit to "0", then services the ED indicated by "CurrentED". If the HC finds a "0" value when checking "ListFilled", it proceeds to the next list.

After servicing the ED, if the current list is a periodic list, the HC checks NextED in the just-completed ED then continues servicing the next ED. If it finds that the NextED value is "0", the HC proceeds to the non-periodic list. For bulk lists, the HC simply proceeds to the next list. For control lists, the next action varies depending on whether or not the number of control EDs indicated by the control/bulk service ratio has been serviced.

Figure 3-14 shows an ED service flowchart.



Figure 3-14. ED Service Flowchart

First, the HC reads the ED to be serviced from the system memory via the PCI bus. Next, the HC determines whether or not that ED actually needs to be serviced. If the ED's Skip bit or Halted bit has a value of "1", the HC skips the ED and proceeds to the next ED or list. If the HC determines that the ED needs to be serviced, it next determines whether or not there are any TDs that can be handled in a queue. The HC compares the ED's TailP and HeadP values and, if the values match, it concludes that the list does not include any valid TDs, so it proceeds to the next ED or list. If the HC services the corresponding TD.

Figure 3-15 shows a TD service flowchart. When the HC services an Isochronous TD, it first calculates the relative frame number to determine whether or not a packet should be sent during the current frame. This relative frame number is used to select Offset [R] and Offset [R+1]. If the relative frame number matches the TD's FrameCount value, Offset [R+1] (BufferEnd+1) is selected. The data buffer size for each transfer is calculated by subtracting Offset [R] from Offset [R+1], and the address is determined based on Offset [R]. When bit 12 of Offset [R] is "0", the Isochronous TD's BufferPage0 is used as the high-order 20 bits of the address. When bit 12 of Offset [R] is "1", the high-order 20 bits of BufferEnd are used as the high-order 20 bits of the address.



Figure 3-15. TD Service Flowchart

When servicing a General TD, the HC gets the next memory address from CurrentBufferPointer. When data is sent to or from the CurrentBufferPointer address, the data may be too large to fit onto one physical page and may therefore occupy several pages. In such cases, the high-order 20 bits of BufferEnd are used instead of the high-order 20 bits of CurrentBufferPointer as the address's high-order 20 bits. The maximum amount of data that can be transferred between devices is their the ED's MaximumPacketSize value or the remaining buffer size, whichever is smaller.

After determining the packet size, the HC must check whether or not it can send the packet before the end of the frame. If the value of the bit time request for the packet to be sent is greater than the frame's remaining bit time value, the packet cannot be sent.

After servicing the General TD, the HC updates four General TD fields: ConditionCode, DataToggle, ErrorCount, and CurrentBufferPointer.

Meanwhile, once Isochronous TD servicing is completed, the HC updates the Offset [R] value to the Packet Status Word.

If the TD is successfully serviced (all data is sent or received) or if an error has occurred, the HC moves the TD to the Done Queue and updates the Done Queue Interrupt Counter. Also, the HC updates the ED to change the values in the HeadP, ToggleCarry, and Halted fields. In order to enqueue the TD into the Done Queue, the HC first copies the current TD's NextTD value to the ED's HeadP field. Next, it writes the HcDoneHead value to the NextTD field of the TD to be enqueued. Finally, it writes the address of the TD to be enqueued to the HcDoneHead field (see Figure 3-16).



Figure 3-16. Done Queue Operations

At this point, the HC uses the TD's final data toggle value to update the ED's ToggleCarry field. If the TD is retired due to an error, the HC also updates the ED's Halted bit.

After the above series of operations, the HC writes the HcDoneHead value to the HCCA and updates the Done Queue Interrupt Counter using the Delay Interrupt value (based on number of issued SOF tokens), which defines the time until an interrupt is generated. However, this counter value is not updated if it is already greater than the Delay Interrupt value of TD.

The Done Queue Interrupt Counter is decremented after each SOF token, and when the counter value reaches "0", the HC writes the current HcDoneHead value to HccaDoneHead immediately at the boundary of the next frame.

After the HcDoneHead value has been written to the HCCA, the HC resets the HcDoneHead value to "0" and sets "1" to the WritebackDoneHead field in HcInterruptStatus, which triggers an interrupt. In this manner, the Done Queue is transferred from the HC to the HCD via the HCCA. The HCD services the Done Queue and supplies notification of completion to the software that requested the transfer.

While WritebackDoneHead is being set, the HC does not write the HcDoneHead value to the HCCA. If another Done Queue has been set up to be received from the HC, WritebackDoneHead is cleared by the HCD.

### 3.8 Legacy Operations

This section describes legacy functions. Legacy functions are provided to directly support the software belonging to an older ("legacy") type of keyboard or mouse device by enabling data from USB keyboard or mouse devices to operate via a legacy keyboard or mouse device interface. These legacy functions are valid when the LEGC pin and AT pin are both clamped to "H". Operations are defined for three conditions: when all connected keyboard/mouse devices are legacy devices, when all are USB devices, and when one or more of each type of device is connected.

Figure 3-17 shows an operational flowchart of input-related legacy functions. When the legacy functions are valid (enabled), the HC first checks HceControl's EmulationEnable and ExternalIRQEn fields. If EmulationEnable has been set to "1", connected USB keyboard or mouse devices are emulated to operate like legacy keyboard or mouse devices (only USB keyboard or mouse devices are valid). If ExternalIRQEn has been set to "1", connected USB keyboard or mouse devices are valid). If ExternalIRQEn has been set to "1", connected USB keyboard or mouse devices are valid). If ExternalIRQEn has been set to "1", connected USB keyboard or mouse devices are valid). If ExternalIRQEn has been set to "1", connected USB keyboard or mouse devices are valid). If ExternalIRQEn has been set to "1", connected USB keyboard or mouse devices are valid). If externalIRQEn has been set to "1", connected USB keyboard or mouse devices are valid). If externalIRQEn has been set to "1", connected USB keyboard or mouse devices are valid). If externalIRQEn has been set to "1", connected USB keyboard or mouse devices are emulated to operate like legacy keyboard or mouse devices, and compatibility of legacy keyboard/mouse operations is maintained (both USB and legacy keyboard or mouse devices are used).



Figure 3-17. Input-related Legacy Operation Flowchart

Note Even if IRI1 is ON, IRQ1Active remains at "L". Similarly, even if IRI2 is ON, IRQ12Active remains at "L".

When "0" is the value of both EmulationEnable and ExternalIRQEn, only legacy keyboard or mouse devices are valid, which means that IRQ1 (keyboard interrupt) and IRQ12 (mouse interrupt) are sent from the keyboard controller to the system directly via the HC. The HC does not receive I/O access (60h/64h), which is direct access to the keyboard controller, and does not perform any special processing.

Figure 3-18 shows an input emulation flowchart for USB keyboard or mouse devices. The HC always performs interrupt list service for each frame. When the transfer that is performed according to the TD is completed, the TD is linked to the Done Queue and a write operation to HccaDoneHead and the WritebackDoneHead interrupt occur after a specified amount of time (Delay Interrupt). If the correctly transferred data includes USB keyboard or mouse data, the system software sets "1" to CharacterPending in HceControl. The HC checks that Command Reg.'s Memory Access field has been set to "1", HceStatus's OutputFull field has been set to "0", HceStatus's CharacterPending field has been set to "1", and HceStatus's EmulationEnable field has been set to "1", after which an emulation interrupt occurs. The output destination for this interrupt is set via HcControl's InterruptRouting field.



Figure 3-18. Input Emulation Flowchart for USB Keyboard/Mouse

Notes 1. MA = PCI Command Reg. Memory Access

- 2. OF = OutputFull
- 3. CP = CharacterPending (set by system software)
- **4.** IR = InterruptRouting
- 5. The WritebackDoneHead interrupt is generated at the same time as the emulation interrupt. The system software acknowledges these interrupts and must clear both of them.
- **6.** AOF = AuxOutputFull

When the system software detects the emulation interrupt, the transferred data is written to HceOutput Reg. (108h) via a memory write operation and "1" is set to the OutputFull field. In addition, "0" is set to HceStatus's AuxOutputFull field if the data is keyboard data and "1" is set to that field if the data is mouse data. At that point, the system software performs operations such as deleting the contents of the TD's DoneQueue field or canceling interrupts. This setting asserts IRO1 (IRQ1) if for keyboard data or IRO2 (IRQ12) if for mouse data. In cases where assertion of the IRO1 or IRO2 signal causes the software to perform I/O read access to address 60h, the HC intercepts this access and outputs the HceOutput value to the data bus instead of the keyboard controller. Next, "0" is set to the OutputFull field, and IRO1 or IRO2 is deasserted. By performing this series of operations, the software is able to handle USB keyboard/mouse data in the same way as legacy keyboard/mouse data.

Figure 3-19 shows a flowchart for when input devices include a combination of USB keyboard or mouse devices and legacy keyboard or mouse devices. In this case, processing of the USB keyboard/mouse data uses the same flow as was described above. Meanwhile, legacy keyboard/mouse data is passed to the system software in the same way as during emulation processing of USB keyboard/mouse data. When "1" has been set to ExternalIRQEn, if an interrupt signal from the keyboard controller is detected, "1" is set to either the IRQ1Active bit or the IRQ12Active bit in HceControl in response to the interrupt signal. When "1" is set to either of these bits, the HC no longer acknowledges I/O access. Next, the HC checks that the Memory Access bit setting is "1", the IRQ1Active or IRQ12Active bit setting is "1", and the ExternalIRQEn bit setting is also "1", then generates an emulation interrupt. At the point when the system software detects the emulation interrupt, data is read from the keyboard controller via 60h I/O access and is written to HceOutput Reg. (108h) via a memory write operation, then "1" is set to the OutputFull field. At the point when the system software confirms assertion of IRO1 (IRQ1) or IRO2 (IRQ12), the HC clears IRQ1Active or IRQ12Active to "0" so that it is again able to respond to I/O access. After this change, assertion of the IRO1 or IRO2 signal enables I/O read access to 60h. When I/O read access to 60h in software is performed, the HC intercepts this access and outputs the HceOutput value to the data bus instead of the keyboard controller, and it sets "0" to OutputFull and deasserts IRO1 or IRO2. During emulation, interrupts from the keyboard controller are masked and are not received.





Notes 1. MA = PCI Command Reg. Memory Access

- 2. IRQ1A = IRQ1Active
- 3. IRQ12A = IRQ12Active
- 4. IR = InterruptRouting
- 5. An emulation interrupt is set independently of EmulationEnable.
- 6. AOF = AuxOutputFull

Figure 3-20 shows a legacy operation flowchart for output operations. When EmulationEnable is "0", only legacy keyboard or mouse devices are valid. Consequently, the HC does not receive I/O access and write operations to I/O address 60h/64h are performed directly from the keyboard controller. When EmulationEnable is "1", the HC intercepts the write operation to I/O address 60h/64h and writes the data to HceInput, then sets "1" to HceStatus's InputFull field. In addition, it sets "0" to HceStatus's CmdData field when data is written to 60h, and it sets "1" to that field when data is written to 64h. Once the HC confirms that "1" has been set to MemoryAccess, InputFull, and EmulationEnable, it generates an emulation interrupt. When writing to a USB keyboard or mouse, the system software reads from HceInput upon detecting the emulation interrupt, and then sets "0" to InputFull. Next, the system software generates data in the TD and USB formats, based on the data that was read, and processes this data via ordinary USB operations. Meanwhile, when writing to a legacy keyboard or mouse, the system software not only reads HceInput and sets "0" to InputFull, it also sets "0" to EmulationEnable. Since setting "0" to EmulationEnable means that the HC no longer receives I/O access, writing to I/O address 60h or 64h is performed by writing directly to the keyboard controller. The value of CmdData is checked to determine whether output is to I/O address 60h or 64h. If a GateA20 sequence occurs, it takes priority over the operations described above.





Notes 1. MA = PCI Command Reg. Memory Access2. IR = InterruptRouting

Figure 3-21. Distinctions between Legacy and USB



**Note** IR = InterruptRouting

GateA20 sequences occur frequently in DOS applications, where they mainly set A20 as valid or invalid. To reduce the number of SMIs that occur due to GateA20, the HC generates an SMI (System Management Interrupt) only when the GateA20 status is to be changed by a GateA20 sequence.

Table 3-5 lists operation conditions and HC operations.

|   |                     | Condition                  | HC                                 |                     |           |
|---|---------------------|----------------------------|------------------------------------|---------------------|-----------|
|   | GateA20<br>Sequence | Value Written to I/O (64h) | Value Written to I/O (64h) (bit 1) | GateA20<br>Sequence | InputFull |
| 1 | 0                   | D1h                        |                                    | $0 \rightarrow 1$   | 0         |
| 2 | 0                   | FFh                        |                                    | 0                   | 1         |
| 3 | 0                   | Except D1h/FFh             |                                    | 0                   | 1         |
| 4 | 1                   | D1h                        |                                    | 1                   | 0         |
| 5 | 1                   | FFh                        |                                    | $1 \rightarrow 0$   | 0         |
| 6 | 1                   | Except D1h/FFh             |                                    | $1 \rightarrow 0$   | 1         |
| 7 | 1                   |                            | Value does not match A20State      | 1                   | 1         |
| 8 | 1                   |                            | Value matches A20State             | 1                   | 0         |

#### Table 3-5. GateA20 Sequences

The system software first sets the A20State for HceControl. Next, it sets the GateA20 sequence as valid by writing D1h to I/O (64h), which sets GateA20Sequence for HceControl. When GateA20Sequence has been set, any data whose bit 1 value is not A20State is written to I/O port 60h and InputFull is set. At that point, HC confirms that "1" has been set to MemoryAccess, InputFull, and EmulationEnable, after which an interrupt occurs. When the system software detects this interrupt, processing of GateA20 begins.

[MEMO]

## CHAPTER 4 POWER MANAGEMENT

# 4.1 Overview of Power Management

This device supports CLKRUN functions and PCI/USB clock stop functions in order to reduce power consumption. This chapter describes the power management approach and related control methods.

#### 4.2 Bus States and Device States

In this device, power management provides separate control of PCI and USB operations. Therefore, to understand these operations, one must first understand the PCI bus states, USB bus states, and device states.

#### (1) PCI bus states

- B0: PCI CLK = 33 MHz (includes CLKRUN operations)
- B1: PCI CLK = Intermittent clock operation mode
- B2: PCI CLK = Stop, PCI BUS power on
- B3: PCI CLK = Stop, PCI BUS power off

#### (2) USB bus states

USB\_Reset: Bus = Reset, USB system is stopped (except for state transition monitoring)

This state is entered when reset mode is canceled. This state can also be entered based on USB Operational Register settings.

USB\_Operational: Bus = Active, USB system is operating normally

This state can be entered based on USB Operational Register settings.

USB\_Suspend: Bus = Suspend, USB system is stopped (except for bus state and state transition monitoring) This state can be entered based on USB Operational Register settings. The state transition can also be caused by S/W\_Reset.

USB\_Resume: Bus = Resume, USB system is operating normally

This state can be entered based on USB Operational Register settings. The state transition can also be caused by connecting or disconnecting devices or by a Wakeup request from a connected device.

#### (3) Device states

- D0: Normal operation mode (PCI = B0, USB = RESET, OPERATIONAL, SUSPEND, or RESUME) The PCI state must be B0, USB state can be any state.
- D2: Device sleep mode (PCI = B0, B1, or B2; USB = RESET, SUSPEND/RESUME)
  - The PCI state can be normal operation, intermittent operation, or suspended operation, but the CPU can access the HC's configuration space and operational registers only during the normal operation state. This restriction exists in order to maintain synchronous periods between the HC and the HCD. The system software and HCD should be coordinated to provide contrast so as to prevent HC operation faults. While in this mode, if the USB state is SUSPEND, a Wakeup operation occurs if a new device connection or disconnection is detected or if the RESUME state is entered in response to a RESUME signal.
- D3: Device disable mode (PCI clock stop, USB = RESET, or power off) The PCI state can be normal operation, intermittent operation, or suspended operation, but the CPU can access the HC's configuration space and operational registers only during the normal operation state. This restriction exists in order to maintain synchronous periods between the HC and the HCD. The system software and HCD should be coordinated to provide contrast so as to prevent HC operation faults. Wakeup operations do not occur.

## 4.3 Transition Conditions for Bus States and Device States

The following conditions must be met for a device state transition to occur.

#### Table 4-1. Device State Transition Conditions

| State Transition    | Transition Condition                                                                               | Transition Request Source |
|---------------------|----------------------------------------------------------------------------------------------------|---------------------------|
| $D0 \rightarrow D2$ | Register setting specifies USB = USB_RESET or SUSPEND state                                        | System                    |
| $D0 \rightarrow D3$ | Register setting specifies USB = USB_RESET state and device's power is<br>off or a HW_RESET occurs | System                    |
| $D2 \rightarrow D0$ | Register setting                                                                                   | System,<br>USB_Wakeup     |
| $D3 \rightarrow D0$ | Register setting                                                                                   | System                    |
| $D2 \rightarrow D3$ | Register setting specifies USB = USB_RESET state and device's power is<br>off or a HW_RESET occurs | System                    |

USB state transitions are defined in the USB specifications. The transition conditions are listed below.

|                     | Transition Condition            |           |           |                   |                     |                      |  |  |  |
|---------------------|---------------------------------|-----------|-----------|-------------------|---------------------|----------------------|--|--|--|
| State Transition    | Operational Register<br>Setting | H/W_Reset | S/W_Reset | Wakeup<br>Request | Attach<br>Detection | Dettach<br>Detection |  |  |  |
| Operational→Reset   | 0                               | 0         | ×         | ×                 | ×                   | ×                    |  |  |  |
| Suspend→Reset       | 0                               | 0         | ×         | ×                 | ×                   | ×                    |  |  |  |
| Resume→Reset        | 0                               | 0         | ×         | ×                 | ×                   | ×                    |  |  |  |
| Reset→Operational   | 0                               | ×         | ×         | ×                 | ×                   | ×                    |  |  |  |
| Operational→Suspend | 0                               | ×         | 0         | ×                 | ×                   | ×                    |  |  |  |
| Suspend→Operational | 0                               | ×         | ×         | ×                 | ×                   | ×                    |  |  |  |
| Suspend→Resume      | 0                               | ×         | ×         | 0                 | 0                   | 0                    |  |  |  |
| Resume→Operational  | 0                               | ×         | ×         | ×                 | ×                   | ×                    |  |  |  |
| Reset→Suspend       | ×                               | ×         | 0         | ×                 | ×                   | ×                    |  |  |  |
| Resume→Suspend      | ×                               | ×         | 0         | ×                 | ×                   | ×                    |  |  |  |

#### Table 4-2. USB State Transition Conditions

#### Remark Wakeup: Wakeup request from USB device

The mutual relation between the device and the external (USB or PCI) interface is determined as follows, according to the previously described relations between the PCI bus and the device state as well as the device/USB state transition information.

| Device State | PCI State | USB State   | Source of Request from USB to PCI | Control Output |
|--------------|-----------|-------------|-----------------------------------|----------------|
| D0           | B0        | Operational | Transaction                       | INTA           |
|              |           | Reset       | _                                 | SMI            |
|              |           | Suspend     |                                   | REQ            |
|              |           | Resume      | Wakeup/Attach/Dettach             | CRUN           |
| D2           | B0        | Reset       | _                                 | _              |
|              |           | Suspend     |                                   |                |
|              |           | Resume      | Wakeup/Attach/Dettach             | WAKE           |
|              | B1        | Reset       | _                                 | _              |
|              |           | Suspend     |                                   |                |
|              |           | Resume      | Wakeup/Attach/Dettach             | WAKE           |
|              | B2        | Reset       | _                                 | _              |
|              |           | Suspend     |                                   |                |
|              |           | Resume      | Wakeup/Attach/Dettach             | WAKE           |
| D3           | B0        | Reset       | -                                 | _              |
|              | B1        | Reset       | _                                 | _              |
|              | B2        | Reset       | _                                 | _              |
|              | B3        | Reset       | -                                 | _              |

### Table 4-3. Mutual Relation between Device State and PCI or USB

Remarks 1. The INTA signal operates completely asynchronously in relation to the PCI clock.

- 2. When the device state is D2, the USB state must be a state other than Operational.
- **3.** When the device state is D3, the USB state must be RESET, the HC must be in power-off state, or an HW\_RST must occur.

#### 4.4 Device State Transition Flow

To prevent faults in USB control operations from occurring due a transition between device states, such control operations must follow a predetermined flow during a state transition. Make sure that such transitions comply with the device state transition flow described in Table 4-4 below. Also, make sure that the HCD and System processing comply with the OpenHCI specifications.

| Device State         | USB State                                | State Transition Control                                      |
|----------------------|------------------------------------------|---------------------------------------------------------------|
| D0<br>(PCI = CLKRUN) | Suspend $\rightarrow$ Resume             | Transition is only when RESUME signal is sent from USB Flow A |
|                      | Operational (bus master REQ)             | Flow B                                                        |
|                      | Operational (interrupt event)            | Flow A                                                        |
|                      | Operational (write to internal register) | Flow C                                                        |
|                      | All other transitions                    | Normal HCD control                                            |
| D2                   | Suspend $\rightarrow$ Resume             | Flow D                                                        |
| D3                   | No transition                            | None                                                          |
| $D0 \rightarrow D2$  | All transitions                          | Flow E                                                        |
| D0  ightarrow D3     | All transitions                          | Flow F                                                        |
| $D2 \rightarrow D3$  | Reset, Suspend                           | Flow F                                                        |
| $D2 \rightarrow D0$  | Reset, Suspend                           | Request from System Flow G<br>USB Wakeup request Flow D       |
| $D3 \rightarrow D0$  | Reset                                    | Don't care                                                    |

#### Table 4-4. State Control

Flow A

| (a) | Assert INTA         | (HC)     |
|-----|---------------------|----------|
| (b) | Normal clock supply | (System) |
| (c) | Interrupt servicing | (System) |
| (d) | Deassert INTA       | (HC)     |
|     |                     |          |

INTA output is synchronized to a 12-MHz clock and there is a delay of up to 170 ns between clearing of the status register and clearing of INTA.

#### Flow B

| (a) | Assert CRUN (only when CLKRUN# is at high level) | (HC)     |
|-----|--------------------------------------------------|----------|
| (b) | Normal clock supply                              | (System) |
| (c) | Assert REQ                                       | (HC)     |
| (d) | PCI bus master operation                         | (HC)     |
| (e) | Deassert REQ                                     | (HC)     |
|     |                                                  |          |

(f) Multiple Clock Continues operation using CRUN, when necessary (HC)

The maximum allowable time between assertion of CRUN and assertion of GNT to a device is 7  $\mu$ s. This is a restriction that applies to REQ for cases where data that includes at least 64 bytes is transferred via an Isochronous Transaction. If more than 7  $\mu$ s elapses before processing is started, some Isochronous data may be lost during transfer. See the specifications of PCI Mobile Design Guide for CRUN operations.

### Flow C

| (a) | Assert CRUN (only when CLKRUN# is at high level) | (HC)     |
|-----|--------------------------------------------------|----------|
| (b) | Normal clock supply                              | (System) |

(b) Normal clock supply

(c) Multiple Clock Continues operation using CRUN, when necessary (HC)

The maximum allowable time between assertion of CRUN and reset to normal clock operation is 5  $\mu$ s. See the specifications of PCI Mobile Design Guide for CRUN operations.

## Flow D

| (a) | Send RESUME signal from USB                   |          |
|-----|-----------------------------------------------|----------|
|     | (only when HCFS = USB_SUSPEND)                | (USB)    |
| (b) | Assert WAKE and set WakeupStatus              | (HC)     |
| (c) | Reset to WAKEUP processing and normal clock   | (System) |
| (d) | Clear WakeupStatus                            | (System) |
| (e) | Deassert WAKE                                 | (HC)     |
| (f) | Set device state to D0 and Wakeup Enable to 0 | (System) |
| (g) | Assert INTA                                   | (HC)     |
| (h) | Interrupt servicing                           | (System) |
| (i) | Deassert INTA                                 | (HC)     |

INTA and WAKE output are synchronized to a 12-MHz clock and there is a delay of up to 170 ns between clearing of the status register and clearing of INTA or WAKE.

## Flow E

| (a) | Set HCFS in HcControl Register to USB_RESET or USB_SUSPEND | (HCD)    |
|-----|------------------------------------------------------------|----------|
| (b) | Set device state to D2                                     | (System) |
| (c) | Set StatusChangeStandby bit                                | (HC)     |
| (d) | Set Wakeup Enable to 1                                     | (System) |
| (e) | Enable PCI bus state change                                | (System) |

When the PCI bus state changes, the system must wait until the StatusChangeStandby bit in the Power Management Control/Status Register goes high. When activating a wakeup via a resume signal from the USB, the HCFS must be set to USB\_SUSPEND.

## Flow F

| (a) | Set HCFS in HcControl Register to USB_RESET | (HCD)    |
|-----|---------------------------------------------|----------|
| (b) | Set device state to D3                      | (System) |
| (c) | Set StatusChangeStandby bit                 | (HC)     |
| (d) | Enable PCI bus state change                 | (System) |
|     |                                             |          |

When the PCI bus state changes, the system must wait until the StatusChangeStandby bit in the Power Management Control/Status Register goes high. Other methods for setting a transition to the D3 state include using power-off or HW\_RST. If using HW\_RST, make sure that synchronization is maintained between the HCD and the HC. In the case of a transition to D3 using HW\_RST, the device does not acknowledge any kind of PCI access. After HW\_RST is cleared, the device state is D0.

Flow G

(a) Normal clock supply

(b) Set device state to D0 and Wakeup Enable to 0

(System) (System)

Special device controls are not required when resetting from the D3 device state via system power-off or an HW\_RST.

[MEMO]

## **CHAPTER 5 REGISTER INFORMATION**

## 5.1 PCI Configuration Space

The configuration register is accessed in order to set up hardware resources, device characteristics or operations, etc. in PCI Local Bus. This chapter describes the PCI Configuration Space, which is the address space for the configuration register. For a more detailed description, see the **PCI Local Bus Specification Revision 2.1**.

| 31 :    | 24 23 16          | 15 8                          | 7 0             | Offset |  |  |  |  |
|---------|-------------------|-------------------------------|-----------------|--------|--|--|--|--|
| D       | evice ID          | Venc                          | Vender ID       |        |  |  |  |  |
|         | Status            | Com                           | Command         |        |  |  |  |  |
|         | Class Code        |                               | Revision ID     | 08h    |  |  |  |  |
| BIST    | Header Type       | Latency Timer                 | Cache Line Size | 0Ch    |  |  |  |  |
|         | BAR_OH            | CI Register                   |                 | 10h    |  |  |  |  |
|         | I/O Address Re    | egister (PC/AT <sup>™</sup> ) |                 | 14h    |  |  |  |  |
|         | I/O Address Regis | ster (PC-98 Series)           |                 | 18h    |  |  |  |  |
|         |                   |                               |                 | 1Ch    |  |  |  |  |
|         | Base Addr         | ess Register                  |                 | 20h    |  |  |  |  |
|         |                   |                               | 24h             |        |  |  |  |  |
|         | Cardbus (         | CIS Pointer                   |                 | 28h    |  |  |  |  |
| Sub     | system ID         | Subsystem                     | 2Ch             |        |  |  |  |  |
|         | Expansion RO      | M Base Address                |                 | 30h    |  |  |  |  |
|         | Res               | erved                         |                 | 34h    |  |  |  |  |
|         | Res               | erved                         |                 | 38h    |  |  |  |  |
| Max_lat | Min_Gnt           | Interrupt Pin                 | Interrupt Line  | 3Ch    |  |  |  |  |
|         |                   |                               |                 | 40h    |  |  |  |  |
|         | 5                 |                               |                 |        |  |  |  |  |
|         | Res               | erved                         |                 |        |  |  |  |  |
|         |                   |                               |                 |        |  |  |  |  |
|         | Power Managem     | ent Control/Status            |                 | E0h    |  |  |  |  |

### Table 5-1. PCI Configuration Space

| Register                               | Address | bits    | Read/<br>Write        | Value<br>(Default) | Comment                                         |
|----------------------------------------|---------|---------|-----------------------|--------------------|-------------------------------------------------|
| Vender ID                              | 00h     | 15 : 0  | R                     | 1033h              | NEC's vendor ID                                 |
| Device ID                              | 02h     | 15 : 0  | R                     | 0035h              | This device's device ID                         |
| Command                                | 04h     | 15 : 0  |                       |                    | See Table 5-1.                                  |
| Status                                 | 06h     | 15 : 0  |                       |                    | See Table 5-4.                                  |
| Revision ID                            | 08h     | 7:0     | R                     | 02h                | Version 2.0                                     |
| Class Code-Base Class                  | 09h     | 23 : 16 | R                     | 0Ch                | Serial Bus Controller Device                    |
| -Sub_Class                             |         | 16 : 8  | R                     | 03h                | USB Device                                      |
| -Programming<br>Interface              |         | 7:0     | R                     | 10h                | Open HCI Host Controller                        |
| Cache Line Size                        | 0Ch     | 7:0     | R                     | 00h                | Cache disabled                                  |
| Latency Timer                          | 0Dh     | 7:3     | R/W                   | 00000b             | Time to continuation of bus cycle               |
|                                        |         | 2:0     | R                     | 000b               |                                                 |
| Header Type                            | 0Eh     | 7:0     | R                     | 00h                | Not a PCI-to-PCI Bridge                         |
| BIST                                   | 0Fh     | 7:0     | R                     | 00h                | BIST is not supported.                          |
| Base Address Register                  | 10h     | 31 : 0  |                       |                    | See Table 5-5.                                  |
| I/O Address Register<br>(PC/AT)        | 14h     | 31 : 0  |                       |                    | See Table 5-6.                                  |
| I/O Address Register<br>(PC-98 Series) | 18h     | 31 : 0  |                       |                    | N.A.                                            |
| Subsystem Vender ID                    | 2Ch     | 15 : 0  | R (/W)                | 0000h              | Write enabled, according to setting of ID Write |
| Subsystem ID                           | 2Eh     | 15 : 0  | R (/W) 0000h Mask bit |                    | Mask bit                                        |
| Interrupt Line                         | 3Ch     | 7:0     | R/W                   | 00h                | Indicates interrupt line's route                |
| Interrupt Pin                          | 3Dh     | 7:0     | R                     | 01h                | Application of INTA#                            |
| Min_Gnt                                | 3Eh     | 7:0     | R                     | 01h                | Minimum request time for burst cycle            |
| Max_lat                                | 3Fh     | 7:0     | R                     | 15h                | Frequency of bus access requests                |

## Table 5-2. Register Information

## Table 5-3. Command Register Information

| Field                              | bit     | Read/<br>Write | Value<br>(Default) | Comment                                     |
|------------------------------------|---------|----------------|--------------------|---------------------------------------------|
| I/O space                          | 0       | R/W            | 0b                 | Controls responses to I/O access            |
| Memory space                       | 1       | R/W            | 0b                 | Controls responses to memory access         |
| Bus Master                         | 2       | R/W            | 0b                 | Controls bus master operations              |
| Special Cycles                     | 3       | R              | 0b                 | Ignores special cycles                      |
| Memory write and invalidate enable | 4       | R              | 0b                 | Sets memory write and invalidate as invalid |
| VGA palette snoop                  | 5       | R              | 0b                 | Sets VGA palette snoop as invalid           |
| Parity Error response              | 6       | R/W            | 0b                 | Controls response to parity error           |
| Wait cycle control                 | 7       | R              | 0b                 | Address/data stepping is not supported.     |
| SERR# enable                       | 8       | R/W            | 0b                 | Controls responses to system errors         |
| Fast back-to-back enable           | 9       | R              | 0b                 | Fast back-to-back access is not supported.  |
| Reserved                           | 15 : 10 | R              | 000000b            | Reserved                                    |

| Field                      | bit    | Read/<br>Write | Value                                                                                                           | Comment                                                                                                |  |
|----------------------------|--------|----------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|
| Reserved                   | 4:0    | R              | 00000b                                                                                                          | Reserved                                                                                               |  |
| 66MHz capable              | 5      | R              | 0b                                                                                                              | 33-MHz operation                                                                                       |  |
| UDF supported              | 6      | R              | 0b                                                                                                              | UDF is not supported.                                                                                  |  |
| Fast back-to-back capable  | 7      | R              | 0b                                                                                                              | Fast back-to-back access is not supported.                                                             |  |
| Data Parity Error detected | 8      | R/W            | met.                                                                                                            | o this bit when the following three conditions are<br>PERR# was asserted by the parity error source or |  |
|                            |        |                | · · /                                                                                                           | tion of PERR# by the target source was detected.                                                       |  |
|                            |        |                | (2) The parity error source was the bus master during the bus<br>cycle in which the data parity error occurred. |                                                                                                        |  |
|                            |        |                | (3) "1" has been set to the command register's Parity Error<br>response bit.                                    |                                                                                                        |  |
| DEVSEL timing              | 10 : 9 | R              | 01b                                                                                                             | DEVSEL# assert timing: Medium speed                                                                    |  |
| Signaled target abort      | 11     | R/W            | The target sets "1" if the bus cycle it is accessing ends due to a target abort condition.                      |                                                                                                        |  |
| Received target abort      | 12     | R/W            | The master sets "1" if the bus cycle it is executing ends due to a target abort condition.                      |                                                                                                        |  |
| Received master abort      | 13     | R/W            | The master sets "1" if the bus cycle it is executing ends due to a master abort condition.                      |                                                                                                        |  |
| Signaled system error      | 14     | R/W            | "1" is set t                                                                                                    | o this bit when SERR# is asserted.                                                                     |  |
| Detected parity error      | 15     | R/W            | "1" is set to this bit when data parity or address parity is detected.                                          |                                                                                                        |  |

## Table 5-4. Status Register Information

## Table 5-5. Base Address (BAR\_OHCI) Register Information

| Field                  | bit     | Read/<br>Write | Value<br>(Default) | Comment                                                                            |
|------------------------|---------|----------------|--------------------|------------------------------------------------------------------------------------|
| Memory space indicator | 0       | R              | 0b                 | Operational registers are mapped to main memory space.                             |
| Туре                   | 2 : 1   | R              | 00b                | Operational registers can be allocated in any part of the 4-G main memory space.   |
| Prefetchable           | 3       | R              | 0b                 | Prefetch is disabled.                                                              |
| Base address (LSB)     | 11 : 4  | R              | 00h                | Operational registers have a 4-Kbyte address space.                                |
| Base address (MSB)     | 31 : 12 | R/W            | 000h               | Indicates the high-order 20 bits of the base address in the Operational registers. |

|                     |        |                | <b>J</b>           | ,                                            |
|---------------------|--------|----------------|--------------------|----------------------------------------------|
| Field               | bit    | Read/<br>Write | Value<br>(Default) | Comment                                      |
| I/O space indicator | 0      | R              | 1b                 | Legacy register is mapped to the I/O space.  |
| Reserved            | 1      | R              | 0b                 | Reserved                                     |
| Base address (LSB)  | 2      | R              | 0b                 | Legacy register has an 8-byte address space. |
| Base address (MSB)  | 31 : 3 | R/W            | 000h               | Indicates the high-order 29 bits of the base |

### Table 5-6. I/O Address Register (PC/AT) Information

**Remark** The I/O Address register is fixed to 0h when legacy support is invalid.

On the other hand, when legacy support is valid, the I/O Address Register (PC-98 Series: offset address 18h) is fixed at 0h.

address in the Legacy register.

| Table 5-7. | Power | Management | Control/Status | Information |
|------------|-------|------------|----------------|-------------|
|------------|-------|------------|----------------|-------------|

| Field                 | bit     | Read/<br>Write | Value<br>(Default) | Comment                                                                                                                                                                           |
|-----------------------|---------|----------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power State           | 1:0     | R/W            | 00b                | Power State Control bit<br>00b = D0 (PCI CLK Full mode: Default)<br>01b = Reserved<br>10b = D2 (PCI CLK Stop and Device power on)<br>11b = D3 (PCI CLK Stop and Device power off) |
| Status Change Standby | 2       | R              | Ob                 | Indicates the device state in relation to control of<br>Power State transitions<br>0b = Not Ready<br>1b = Ready                                                                   |
| Bus Master Control    | 3       | R/W            | 0b                 | Controls PCI command register's bit 2 (bus master bit)<br>0b = Bus master bit is invalid (ordinary bus<br>master operation)<br>1b = Bus master bit is valid                       |
| Reserved              | 4       | R              | 0b                 | Reserved                                                                                                                                                                          |
| REQ_Enable            | 5       | R/W            | Ob                 | REQ signal output timing control<br>0b = PCI clock synchronous output: Default<br>1b = PCI clock asynchronous output                                                              |
| PC_mode               | 6       | R/W            | 0b                 | PC-98 Series / PC/AT switch setting control<br>0b = PC-98 Series mode: Default<br>1b = PC/AT mode                                                                                 |
| ID Write Mask         | 7       | R/W            | 0b                 | Write protection of Subsystem ID and Subsystem<br>Vendor ID<br>0b = Write Mask: Default<br>1b = Write Enable                                                                      |
| Wakeup_Status         | 8       | R/W            | 0b                 | "1" is set when a Wakeup request has been<br>issued. Writing "1" clears the bit, but writing "0"<br>does not change it.                                                           |
| Reserved              | 15 : 9  | R              | 0b                 | Reserved                                                                                                                                                                          |
| Wakeup_Enable         | 16      | R/W            | Ob                 | Output control of WAKE signal<br>0b = WAKE signal is invalid: Default<br>1b = WAKE signal is valid                                                                                |
| Reserved              | 31 : 17 | R              | 0b                 | Reserved                                                                                                                                                                          |

- **Remarks 1.** Be sure to use REQ\_Enable the default. If used asynchronously, it may no longer comply with the PCI specifications.
  - The Power State bit is invalid when PC\_mode = 0. The system has read/write access to the Power State bit. The HC has read-only access.
  - 3. The Wakeup\_Status bit is invalid when PC\_mode = 0. When PC\_mode = 1, Power State = 10, and HCFS = USBSUSPEND, "1" is set when a RESUME signal from the USB is detected. At that point, if the Wakeup\_Enable bit = 1, the WAKE signal is asserted. Writing "1" clears this bit and simultaneously deasserts WAKE. The above operations occur only when the HcInterruptEnable register's RHSC/RD bit has been set.
  - 4. The Wakeup\_Enable bit is invalid when PC\_mode = 0.
  - 5. After the Power State bit has been set as D2 or D3, "0" is output as the Status Change Standby value until the state transition is actually ready to occur, after which "1" is output. Once the Status Change Standby value becomes "1" after the Power State bit has been set as D2 or D3, it does not revert back to "0". This bit's value is always "0" when the Power State bit has been set as D0.
  - 6. The Bus Master Control bit switches the command register's bus master bit's valid/invalid setting. When the Bus Master Control bit's value is "0", bus master operations are valid whether or not the bus master bit's value is set to "0".



#### Figure 5-1. OpenHCI's PCI Configuration Space

The PCI Configuration Space's Base Address (BAR\_OHCI) Register is in an OpenHCI-compliant host controller. It indicates the base address of Operational Registers which are the starting point for communication with the host CPU.

#### 5.2 Operational Registers

The host controller includes the Operational Registers, which are the starting point for communication with the host CPU. This set of registers is mapped to a 4-Kbyte range in the 4-Gbyte main memory space, where it is used by the HCD (Host Controller Driver). All of the registers in this set are read from or written to in Dword units. For a more detailed description, see the **Open HCI Specification Release 1.0** and **OpenHCI Legacy Support Interface Specification Release Version 1.01**.

| 31                 | 0 | Offset |
|--------------------|---|--------|
| HcRevision         |   | 00h    |
| HcControl          |   | 04h    |
| HcCommandStatus    |   | 08h    |
| HcInterruptStatus  |   | 0Ch    |
| HcInterruptEnable  |   | 10h    |
| HcInterruptDisable |   | 14h    |
| HcHCCA             |   | 18h    |
| HcPeriodCurrentED  |   | 1Ch    |
| HcControlHeadED    |   | 20h    |
| HcControlCurrentED |   | 24h    |
| HcBulkHeadED       |   | 28h    |
| HcBulkCurrentED    |   | 2Ch    |
| HcDoneHead         |   | 30h    |
| HcFmInterval       |   | 34h    |
| HcFmRemaining      |   | 38h    |
| HcFmNumber         |   | 3Ch    |
| HcPeriodicStart    |   | 40h    |
| HcLSThreshold      |   | 44h    |
| HcRhDescriptorA    |   | 48h    |
| HcRhDescriptorB    |   | 4Ch    |
| HcRhStatus         |   | 50h    |
| HcRhPortStatus1    |   | 54h    |
| HcRhPortStatus2    |   | 58h    |

### Table 5-8. Host Controller Operational Registers

#### Table 5-9. Legacy Support Registers

| _ | 31         | 0 | Memory Offset | I/O Address |
|---|------------|---|---------------|-------------|
|   | HceControl |   | 100h          |             |
|   | HceInput   |   | 104h          | 60h/64h     |
|   | HceOutput  |   | 108h          | 60h         |
|   | HceStatus  |   | 10Ch          | 64h         |

## 5.2.1 Overview of operational registers

## **Register: HcRevision**

Offset Address: 00h

| Field    | Bit    | Read/Write |     | Value<br>(Default) | Comment                                                                                                                                                           |
|----------|--------|------------|-----|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |        | пср        | пр  | (Deradit)          |                                                                                                                                                                   |
| Revision | 7:0    | R          | R   | 10h                | Complies with OpenHCI R1.0                                                                                                                                        |
| Legacy   | 8      | R          | R/W | Xb                 | Includes a legacy support register. It is set to suit the setting of external pin LEGC.<br>LEGC = $0 \rightarrow$ Set to "0"<br>LEGC = $1 \rightarrow$ Set to "1" |
| Reserved | 31 : 9 | R/W        | R   | Xh                 | Reserved                                                                                                                                                          |

## Register: HcControl

Offset Address: 04h

| <b>5</b> . 11                                    |         | Read | /Write | Value                                                                  |                                                                                                                                                |
|--------------------------------------------------|---------|------|--------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Field                                            | Bit     | HCD  | HD     | (Default)                                                              | Comment                                                                                                                                        |
| ControlBulkServiceRatio<br>(CBSR)                | 1:0     | R/W  | R      | 00b                                                                    | Indicates the control/bulk service ratio between EDs.CBSRNo. of Control EDs Over Bulk EDs Served01:112:123:134:1                               |
| PeriodicListEnable (PLE)                         | 2       | R/W  | R      | 0b                                                                     | Sets the next frame's periodic list servicing as valid or invalid.<br>1: Valid, 0: Invalid                                                     |
| IsochronousEnable (IE)                           | 3       | R/W  | R      | Ob                                                                     | Sets the next frame's isochronous ED servicing as valid or<br>invalid.<br>1: Valid, 0: Invalid                                                 |
| ControlListEnable (CLE)                          | 4       | R/W  | R      | 0b                                                                     | Sets the next frame's control list servicing as valid or invalid.<br>1: Valid, 0: Invalid                                                      |
| BulkListEnable (BLE)                             | 5       | R/W  | R      | 0b                                                                     | Sets the next frame's bulk list servicing as valid or invalid.<br>1: Valid, 0: Invalid                                                         |
| HostControllerFunctionalState<br>for USB (HCFS)  | 7:6     | R/W  | R/W    | 00b<br>(H/W_R <sup>Note 1</sup> )<br>11b<br>(S/W_R <sup>Note 2</sup> ) | 00b: UsbReset<br>01b: UsbResum<br>10b: UsbOperational<br>11b: UsbSuspend                                                                       |
| InterruptRouting (IR) <sup>Note 3</sup>          | 8       | R/W  | R      | Ob                                                                     | This bit indicates the route of an interrupt that is triggered<br>by an event registered in HcInterruptStatus.<br>1: SMI output, 0: INT output |
| RemoteWakeupConnected<br>(RWC) <sup>Note 3</sup> | 9       | R/W  | R/W    | Ob                                                                     | This bit indicates whether or not remote wakeup signals<br>are supported.<br>1: Supported, 0: Not supported                                    |
| RemoteWakeupEnable<br>(RWE)                      | 10      | R/W  | R      | 0b                                                                     | Sets remote wakeup signal as valid or invalid when upstream resume signal is detected.                                                         |
| Reserved                                         | 31 : 11 | R/W  | R      | Xh                                                                     | Reserved                                                                                                                                       |

Notes 1. H/W\_R = Hardware Reset

- 2. S/W\_R = Software Reset
- **3.** Only Hardware Reset is available.

## Register: HcCommandStatus

Offset Address: 08h

| Field                           | Read/Write | /Write | Value | Comment   |                                                                                                                                        |
|---------------------------------|------------|--------|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------|
| Field                           | Bit        | HCD    | HD    | (Default) | Comment                                                                                                                                |
| HostControllerReset (HCR)       | 0          | R/W    | R/W   | 0b        | HC software reset. This bit is set by the HCD and cleared by the HC.                                                                   |
| ControlListFilled (CLF)         | 1          | R/W    | R/W   | 0b        | Indicates whether or not a TD exists in the control list.                                                                              |
| BulkListFilled (BLF)            | 2          | R/W    | R/W   | 0b        | Indicates whether or not a TD exists in the bulk list.                                                                                 |
| OwnershipChangeRequest<br>(OCR) | 3          | R/W    | R/W   | 0b        | This bit is set by the HCD to request modification of HC control.                                                                      |
| Reserved                        | 15 : 4     | R/W    | R     | Xh        | Reserved                                                                                                                               |
| SchedulingOverrunCount<br>(SOC) | 17 : 16    | R      | R/W   | 00b       | This bit is incremented when a scheduling overrun error occurs. It is initialized by 00b and is returned to its previous value by 11b. |
| Reserved                        | 31 : 18    | R/W    | R     | Xh        | Reserved                                                                                                                               |

# Register: HcInterruptStatus

Offset Address: 0Ch

| Field                         | Bit    | Read/Write |     | Value     | Comment                                                                                                                                                                                 |
|-------------------------------|--------|------------|-----|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field                         | ы      | HCD        | HD  | (Default) | Comment                                                                                                                                                                                 |
| SchedulingOverrun (SO)        | 0      | R/W        | R/W | 0b        | This bit is set when an overrun occurs during USB scheduling of the current frame.                                                                                                      |
| WritebackDoneHead (WDH)       | 1      | R/W        | R/W | Ob        | This bit is set when HcDoneHead has been written to<br>HccaDoneHead. The HCD clears this bit after the<br>contents of HccaDoneHead have been saved.                                     |
| StartofFrame (SF)             | 2      | R/W        | R/W | 0b        | This bit is set at the start of a frame.                                                                                                                                                |
| ResumeDetected (RD)           | 3      | R/W        | R/W | 0b        | This bit is set when a resume signal has been detected.                                                                                                                                 |
| UnrecoverableError (UE)       | 4      | R/W        | R/W | 0b        | This bit is set when a system error that is unrelated to USB has been detected.                                                                                                         |
| FrameNumberOverflow<br>(FNO)  | 5      | R/W        | R/W | Ob        | This bit is set when the value of the MSb (bit 15) of HcFmNumber has changed from "0" to "1" or from "1" to "0".                                                                        |
| RootHubStatusChange<br>(RHSC) | 6      | R/W        | R/W | 0b        | This bit is set when the contents of either HcRhStatus or HcRhPortStatusX are changed.                                                                                                  |
| Reserved                      | 29 : 7 | R/W        | R   | Xh        | Reserved                                                                                                                                                                                |
| OwnershipChange (OC)          | 30     | R/W        | R/W | 0b        | This bit is set by the HC when the HCD has set the OCR field in the HcCommandStatus register. If this event is not masked, it immediately triggers a system management interrupt (SMI). |
| other                         | 31     | R          | R   | 0b        |                                                                                                                                                                                         |

# Register: HcInterruptEnable

Offset Address: 10h

| <b>E</b> . 11                    |        | Read | /Write | Value     |                                                                                                                            |
|----------------------------------|--------|------|--------|-----------|----------------------------------------------------------------------------------------------------------------------------|
| Field                            | Bit    | HCD  | HD     | (Default) | Comment                                                                                                                    |
| SO                               | 0      | R/W  | R      | 0b        | 0: Ignore 1: Interrupt is triggered by Scheduling Overrun                                                                  |
| WDH                              | 1      | R/W  | R      | 0b        | 0: Ignore<br>1: Interrupt is triggered by HcDoneHead Writeback                                                             |
| SF                               | 2      | R/W  | R      | 0b        | 0: Ignore<br>1: Interrupt is triggered by Start of Frame                                                                   |
| RD                               | 3      | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is triggered by Resume Detect</li></ul>                                             |
| UE                               | 4      | R/W  | R      | 0b        | 0: Ignore 1: Interrupt is triggered by Unrecoverable Error                                                                 |
| FNO                              | 5      | R/W  | R      | 0b        | 0: Ignore 1: Interrupt is triggered by Frame Number Overflow                                                               |
| RHSC                             | 6      | R/W  | R      | 0b        | 0: Ignore<br>1: Interrupt is triggered by Root Hub Status Change                                                           |
| Reserved                         | 29 : 7 | R/W  | R      | Xh        | Reserved                                                                                                                   |
| OC                               | 30     | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is triggered by Ownership Change</li></ul>                                          |
| Master Interrupt Enable<br>(MIE) | 31     | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt triggering is enabled when an event other than those listed above occurs.</li></ul> |

# Register: HcInterruptDisable

Offset Address: 14h

| Field                            | Bit    | Read | /Write | Value     | Comment                                                                                                                     |
|----------------------------------|--------|------|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------|
| Field                            | DIL    | HCD  | HD     | (Default) | Comment                                                                                                                     |
| SO                               | 0      | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is not triggered by Scheduling Overrun</li></ul>                                     |
| WDH                              | 1      | R/W  | R      | 0b        | 0: Ignore<br>1: Interrupt is not triggered by HcDoneHead Writeback                                                          |
| SF                               | 2      | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is not triggered by Start of Frame</li></ul>                                         |
| RD                               | 3      | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is not triggered by Resume Detect</li></ul>                                          |
| UE                               | 4      | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is not triggered by Unrecoverable Error</li></ul>                                    |
| FNO                              | 5      | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is not triggered by Frame Number Overflow</li></ul>                                  |
| RHSC                             | 6      | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is not triggered by Root Hub Status Change</li></ul>                                 |
| Reserved                         | 29 : 7 | R/W  | R      | Xh        | Reserved                                                                                                                    |
| ос                               | 30     | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt is not triggered by Ownership Change</li></ul>                                       |
| Master Interrupt Enable<br>(MIE) | 31     | R/W  | R      | 0b        | <ul><li>0: Ignore</li><li>1: Interrupt triggering is disabled when an event other than those listed above occurs.</li></ul> |

## **Register: HcHCCA**

### Offset Address: 18h

| Field                        | Bit    | Read,<br>HCD | Write<br>HD | Value<br>(Default) | Comment                                                                                                |
|------------------------------|--------|--------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| Host Controller              | 7:0    | R            | R           | 00h                | This is the base address of the Host Controller                                                        |
| Communication Area<br>(HCCA) | 31 : 8 | R/W          | R           | 0h                 | Communication Area.<br>Since it is allocated in 256-byte units, the low-order 8 bits are fixed at "0". |

## Register: HcPeriodCurrentED

## Offset Address: 1Ch

| Field                  |        | Read/Write |     | Value     | Comment                                                     |
|------------------------|--------|------------|-----|-----------|-------------------------------------------------------------|
| Field                  | Bit    | HCD        | HD  | (Default) | Comment                                                     |
| PeriodCurrentED (PCED) | 3:0    | R          | R   | 00h       | This is the physical address of an Isochronous or Interrupt |
|                        | 31 : 4 | R          | R/W | 0h        | ED in the periodic list being serviced during the current   |
|                        |        |            |     |           | frame.                                                      |
|                        |        |            |     |           | Since the ED is allocated in 16-byte units, the low-order 4 |
|                        |        |            |     |           | bits are fixed at "0".                                      |

### Register: HcControlHeadED

## Offset Address: 20h

| Field                |        | Read | /Write | Value     | Comment                                                     |
|----------------------|--------|------|--------|-----------|-------------------------------------------------------------|
| Field                | Bit    | HCD  | HD     | (Default) | Comment                                                     |
| ControlHeadED (CHED) | 3:0    | R    | R      | 00h       | This is the physical address of the first ED in the control |
|                      | 31 : 4 | R/W  | R      | 0h        | list.                                                       |

## Register: HcControlCurrentED

## Offset Address: 24h

| Field                   | D:+    | Read | /Write | Value     | Comment                                               |
|-------------------------|--------|------|--------|-----------|-------------------------------------------------------|
| Field                   | Bit    | HCD  | HD     | (Default) | Comment                                               |
| ControlCurrentED (CCED) | 3:0    | R    | R      | 00h       | This is the physical address of the current ED in the |
|                         | 31 : 4 | R/W  | R/W    | 0h        | control list.                                         |

Register: HcBulkHeadED

### Offset Address: 28h

| Field             |        | Read | /Write | Value     | Comment                                                        |
|-------------------|--------|------|--------|-----------|----------------------------------------------------------------|
| Field             | Bit    | HCD  | HD     | (Default) | Comment                                                        |
| BulkHeadED (BHED) | 3:0    | R    | R      | 00h       | This is the physical address of the first ED in the bulk list. |
|                   | 31 : 4 | R/W  | R      | 0h        |                                                                |

# Register: HcBulkCurrentED

## Offset Address: 2Ch

| <b>Field</b>         |        | Read | /Write | Value     |                                                            |
|----------------------|--------|------|--------|-----------|------------------------------------------------------------|
| Field                | Bit    | HCD  | HD     | (Default) | Comment                                                    |
| BulkCurrentED (BCED) | 3:0    | R    | R      | 00h       | This is the physical address of the current ED in the bulk |
|                      | 31 : 4 | R/W  | R/W    | 0h        | list.                                                      |

## Register: HcDoneHead

Offset Address: 30h

| Field         | Bit    | Read/Write |     | Value     | Comment                                                    |
|---------------|--------|------------|-----|-----------|------------------------------------------------------------|
| Field         | ы      | HCD        | HD  | (Default) | Comment                                                    |
| DoneHead (DH) | 3:0    | R          | R   | 00h       | This is the physical address of the last TD to be added to |
|               | 31 : 4 | R          | R/W | 0h        | the Done queue.                                            |

## Register: HcFmInterval

Offset Address: 34h

| Field                          | Bit     | Read,<br>HCD | /Write<br>HD | Value<br>(Default) | Comment                                                                                  |
|--------------------------------|---------|--------------|--------------|--------------------|------------------------------------------------------------------------------------------|
| FrameInterval (FI)             | 13 : 0  | R/W          | R            | 2EDFh              | This bit indicates a bit time value for the time interval per frame.                     |
| Reserved                       | 15 : 14 | R/W          | R            | Xh                 | Reserved                                                                                 |
| FSLargestDataPacket<br>(FSMPS) | 30 : 16 | R/W          | R            | 0000h              | This is the maximum number of data bits that can be sent or received in one transaction. |
| FrameIntervalToggle (FIT)      | 31      | R/W          | R            | 0b                 | This is inverted when loading to FI.                                                     |

## Register: HcFmRemaining

## Offset Address: 38h

| Field                         | Dit     | Read/Write |     | Value     |                                                                                                      |
|-------------------------------|---------|------------|-----|-----------|------------------------------------------------------------------------------------------------------|
| Field                         | Bit     | HCD        | HD  | (Default) | Comment                                                                                              |
| FrameRemaining (FR)           | 13 : 0  | R          | R/W | 0h        | This is a 14-bit down counter which indicates the remaining bit time in the current frame.           |
| Reserved                      | 30 : 14 | R/W        | R   | Xh        | Reserved                                                                                             |
| FrameRemainingToggle<br>(FRT) | 31      | R          | R/W | 0b        | When the value of FR becomes "0", a value is loaded from the FIT field of the HcFmInterval register. |

## Register: HcFmNumber

Offset Address: 3Ch

| Field            | Bit     |     | Write | Value     | Comment                                                                      |
|------------------|---------|-----|-------|-----------|------------------------------------------------------------------------------|
|                  |         | HCD | HD    | (Default) |                                                                              |
| FrameNumber (FN) | 15 : 0  | R   | R/W   | 0h        | This is a 16-bit counter that is incremented when HcFmRemaining is reloaded. |
| Reserved         | 31 : 16 | R/W | R     | Xh        | Reserved                                                                     |

## Register: HcPeriodicStart

Offset Address: 40h

| Field              |         |     | Write | Value     |                                                                                                |
|--------------------|---------|-----|-------|-----------|------------------------------------------------------------------------------------------------|
| Field              | Bit     | HCD | HD    | (Default) | Comment                                                                                        |
| PeriodicStart (PS) | 13 : 0  | R/W | R     | 0h        | This indicates that periodic list servicing should be started.<br>The standard value is 3E67h. |
| Reserved           | 31 : 14 | R/W | R     | Xh        | Reserved                                                                                       |

## Register: HcLSThreshold

Offset Address: 44h

| Field             | Bit     | Read/<br>HCD | /Write<br>HD | Value<br>(Default) | Comment                                                                                                    |
|-------------------|---------|--------------|--------------|--------------------|------------------------------------------------------------------------------------------------------------|
| LSThreshold (LST) | 11:0    | R/W          | R            | 0628h              | This includes a value that is used to determine whether or not to send the LS packet before the EOF token. |
| Reserved          | 31 : 12 | R/W          | R            | Xh                 | Reserved                                                                                                   |

## Register: HcRhDescriptorA

## Offset Address: 48h

| Field                                               | Bit     | Read | /Write |     | Comment                                                                                                                                                  |
|-----------------------------------------------------|---------|------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field                                               | ы       | HCD  | HD     |     | Comment                                                                                                                                                  |
| NumberDownstreamPorts<br>(NDP) <sup>Note</sup>      | 7:0     | R    | R      | 02h | This bit indicates the number of downstream ports that are supported by the root hub.                                                                    |
| PowerSwitchingMode<br>(PSM) <sup>Note</sup>         | 8       | R/W  | R      | 1b  | <ul><li>0: Power supply is applied to all ports at the same time.</li><li>1: Power supply is applied separately to each port.</li></ul>                  |
| NoPowerSwitching (NPS) <sup>Note</sup>              | 9       | R/W  | R      | Ob  | <ul><li>0: Power supply to ports can be switched on and off.</li><li>1: Power supply to ports is always applied when HC's power is on.</li></ul>         |
| DeviceType (DT) <sup>№te</sup>                      | 10      | R    | R      | 0b  | Indicates that the root hub is not a hybrid type of device.                                                                                              |
| OverCurrentProtectionMode<br>(OCPM) <sup>Note</sup> | 11      | R/W  | R      | 1b  | <ol> <li>Overcurrent status is reported to all downstream ports<br/>at once.</li> <li>Overcurrent status is reported separately to each port.</li> </ol> |
| NoOverCurrentProtection<br>(NOCP) <sup>Note</sup>   | 12      | R/W  | R      | 0b  | <ul><li>0: Overcurrent status is reported.</li><li>1: Overcurrent protection is not supported.</li></ul>                                                 |
| Reserved                                            | 23 : 13 | R/W  | R      | Xh  | Reserved                                                                                                                                                 |
| PowerOnToPowerGoodTime<br>(POTPGT) <sup>Note</sup>  | 31 : 24 | R/W  | R      | FFh | This bit indicates the amount of time that the HCD must<br>wait before accessing the root hub port to which a power<br>supply is applied.                |

**Note** This field can only be used for hardware resets.

Register: HcRhDescriptorB

Offset Address: 4Ch

| Field                                          | Bit     | Read/Write |      | Value     | Comment                                                                                                                                                         |
|------------------------------------------------|---------|------------|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field                                          | DIL     | HCD        | ) HD | (Default) | Comment                                                                                                                                                         |
| DeviceRemovable (DR) <sup>Note</sup>           | 15:0    | R/W        | R    | 0000h     | bit0: Reserved<br>bit1: Device is connected to Port#1<br>bit2: Device is connected to Port#2<br>:<br>bit15: Device is connected to Port#15                      |
| PortPowerControlMask<br>(PPCM) <sup>Note</sup> | 31 : 16 | R/W        | R    | FFFEh     | bit0: Reserved<br>bit1: Power supply to Port#1 set is masked<br>bit2: Power supply to Port#2 set is masked<br>:<br>bit15: Power supply to Port#15 set is masked |

Note This field can only be used for hardware resets.

## Register: HcRhStatus

Offset Address: 50h

|                                                      |         | Read | /Write | Value     |                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------------|---------|------|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field                                                | Bit     | HCD  | HD     | (Default) | Comment                                                                                                                                                                                                                                                                                                     |
| LocalPowerStatus (LPS) <sup>Note</sup>               | 0       | R    | R      | 0b        | The root hub does not support local power status.                                                                                                                                                                                                                                                           |
| ClearGlobalPower (CGP) <sup>Note</sup>               |         | W    | R      | Ob        | <ol> <li>Power supply to all ports is off when PSM = 0.</li> <li>When PSM = 1, only PPS is cleared for ports where<br/>PPCM has not been set.</li> <li>No change</li> </ol>                                                                                                                                 |
| OverCurrentIndicator<br>(OCI) <sup>Note</sup>        | 1       | R    | R/W    | Ob        | <ul> <li>The following occurs when overcurrent status is reported to all downstream ports at once.</li> <li>1: Overcurrent status exists</li> <li>0: Normal power supply operations <ul> <li>Be sure that this is set to "0" when overcurrent status is to be reported to each port.</li> </ul> </li> </ul> |
| Reserved                                             | 14 : 2  | R/W  | R      | Xh        | Reserved                                                                                                                                                                                                                                                                                                    |
| DeviceRemoteWakeupEnable<br>(DRWE) <sup>№00</sup>    | 15      | R    | R      | 0b        | <ul><li>0: CSC is not a remote wakeup event</li><li>1: CSC is a remote wakeup event</li></ul>                                                                                                                                                                                                               |
| SetRemoteWakeupEnable<br>(SRWE) <sup>Note</sup>      |         | W    | R      | 0b        | 1: Sets RWE<br>0: No change                                                                                                                                                                                                                                                                                 |
| LocalPowerStatusChange<br>(LPSC) <sup>Note</sup>     | 16      | R    | R      | 0b        | The root hub does not support local power status.                                                                                                                                                                                                                                                           |
| SetGlobalPower (SGP) <sup>Note</sup>                 |         | W    | R      | Ob        | <ol> <li>Power supply to all ports is on when PSM = 0.</li> <li>When PSM = 1, only PPS is set for ports where PPCM has not been set.</li> <li>No change</li> </ol>                                                                                                                                          |
| OverCurrentIndicatorChange<br>(CCIC) <sup>Note</sup> | 17      | R/W  | R/W    | Ob        | HC sets "1" when a change has occurred in OCI. It is cleared when the HCD writes "1". There is no change when the HCD writes "0".                                                                                                                                                                           |
| Reserved                                             | 30 : 18 | R/W  | R      | Xh        | Reserved                                                                                                                                                                                                                                                                                                    |
| ClearRemoteWakeupEnable<br>(CRWE) <sup>Note</sup>    | 31      | W    | R      | 0b        | 1: Clears RWE<br>0: No change                                                                                                                                                                                                                                                                               |
| other                                                |         | R    | R      | 0b        |                                                                                                                                                                                                                                                                                                             |

**Note** This field can only be used for hardware resets.

## Register: HcRhPortStatus [1:2]

Offset Address: 54h, 58h

| Field                                              | Bit | Read | /Write | Value     | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------|-----|------|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field                                              | DIL | HCD  | HD     | (Default) | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CurrentConnectStatus<br>(CCS) <sup>Note</sup>      | 0   | R    | R/W    | Ob        | This bit is set when a device has been connected.<br>This bit is cleared when the device is disconnected or<br>when the power to the port is turned off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PortEnableStatus (PES) <sup>Note</sup>             | 1   | R    | R/W    | Ob        | <ul> <li>This bit is set by the following conditions.</li> <li>When SPE is issued while CCS = 1</li> <li>When PRSC is set</li> <li>When PSSC is set</li> <li>It is cleared by the following conditions.</li> <li>When an overcurrent occurs</li> <li>When a device is disconnected</li> <li>When the port's power is off</li> <li>When an operational error, such as bubble detection, occurs</li> <li>When CPE is issued</li> </ul>                                                                                                                                                                                                                                                                                                                            |
| PortSuspendStatus<br>(PSS) <sup>№™</sup>           | 2   | R    | R/W    | 0b        | This bit is set when SPS is issued while CCS = 1.<br>It is cleared when PSSC or PRSC is set, when HCFS = 01b, or when the port's power is off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| PortOverCurrentIndicator<br>(POCI) <sup>Note</sup> | 3   | R    | R/W    | Ob        | This bit is set when an overcurrent has occurred while<br>NOCP = 0 and OCPM = 1.<br>It is cleared when the setting condition is canceled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| PortResetStatus (PRS) <sup>Note</sup>              | 4   | R    | R/W    | 0b        | This bit is set when SPR is issued while CCS = 1.<br>It is cleared when PSSC or PRSC is set, when HCFS =<br>01b, or when the port's power is off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| PortPowerStatus (PPS) <sup>Note</sup>              | 8   | R    | R/W    | Ob        | <ul> <li>This bit is set by the following conditions.</li> <li>When SGP is issued while NPS = 1 or NPS = 0, and PSM = 0.</li> <li>When SGP is issued while NPS = 0, PSM = 1, and the corresponding bit in PPCM = 0</li> <li>When SPP is issued while NPS = 0, PSM = 1, and the corresponding bit in PPCM = 1</li> <li>It is cleared by the following conditions.</li> <li>When CGP is issued while NPS = 1 or NPS = 0, and PSM = 0</li> <li>When CGP is issued while NPS = 0, PSM = 1, and the corresponding bit in PPCM = 0</li> <li>When CGP is issued while NPS = 0, PSM = 1, and the corresponding bit in PPCM = 1</li> <li>When CPP is issued while NPS = 0, PSM = 1, and the corresponding bit in PPCM = 1</li> <li>When an overcurrent occurs</li> </ul> |
| LowSpeedDeviceAttached<br>(LSDA) <sup>Note</sup>   | 9   | R    | R/W    | 0b        | This bit is set when a low-speed device is connected.<br>It is cleared when a full-speed device is connected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ConnectStatusChange<br>(CSC) <sup>Note</sup>       | 16  | R/W  | R/W    | Ob        | <ul> <li>This bit is set by the following conditions.</li> <li>By a change in CCS or by setting of the corresponding bit in DR</li> <li>SPR/SPE/SPS is issued when CCS = 0.</li> <li>It is cleared when "1" is written by the HCD.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Field                                                     |     | Read | /Write | Value     | Comment                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------|-----|------|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field                                                     | Bit | HCD  | HD     | (Default) | Comment                                                                                                                                                                                                                                                                                                     |
| PortEnableStatusChange<br>(PESC) <sup>№0®</sup>           | 17  | R/W  | R/W    | Ob        | <ul> <li>This bit is set by the following conditions.</li> <li>When an overcurrent occurs</li> <li>When a device is disconnected</li> <li>When a port's power is off</li> <li>When an operational error, such as bubble detection, occurs</li> <li>It is cleared when "1" is written by the HCD.</li> </ul> |
| PortSuspendStatusChange<br>(PSSC) <sup>№™</sup>           | 18  | R/W  | R/W    | Ob        | This bit is set by completion of a RESUME signal.<br>It is cleared when "1" is written by the HCD or when PRSC<br>is set.                                                                                                                                                                                   |
| PortOverCurrentIndicator<br>Change (OCIC) <sup>Note</sup> | 19  | R/W  | R/W    | 0b        | This bit is set when POCI changes.<br>It is cleared when "1" is written by the HCD.                                                                                                                                                                                                                         |
| PortResetStatusChange<br>(PRSC) <sup>№0®</sup>            | 20  | R/W  | R/W    | 0b        | This bit is set by completion of a RESET signal.<br>It is cleared when "1" is written by the HCD.                                                                                                                                                                                                           |

**Note** This field can only be used for hardware resets.

| Deviator   | Memory Address |             | Read/Write | Comment                                                                                                                                      |
|------------|----------------|-------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Register   | Offset         | I/O Address | HCD        | Comment                                                                                                                                      |
| HceControl | 100h           |             | R/W        | This register is used to transmit various types of status<br>information such as setting emulation hardware as valid,<br>and controlling it. |
| HceStatus  | 10Ch           |             | R/W        | This is the legacy status register for emulation. Input from                                                                                 |
|            |                | 64h         | R          | port 64h indicates the current value of HceStatus without causing other operations.                                                          |
| HceInput   | 104h           |             | R/W        | This is the legacy input buffer register for emulation.                                                                                      |
|            |                | 60h         | W          | Output to port 60h sets "1" to InputFull and "0" to CmdData                                                                                  |
|            |                | 64h         | W          | in the HceStatus register.<br>Output to port 64h sets "1" to InputFull and CmdData in<br>the HceStatus register.                             |
| HceOutput  | 108h           |             | R/W        | This is the legacy output buffer register for emulation in                                                                                   |
|            |                | 60h         | R          | which software writes to a keyboard or mouse device.<br>Input from port 60h sets "0" to OutputFull in the HceStatus<br>register.             |

## 5.2.2 Overview of legacy support registers

**Remark** When emulation is enabled (valid), the HceStatus, HceInput, and HceOutput registers can be accessed via I/O addresses 60h and 64h.

## **Register: HceInput**

| Field     | bit    | Read/Write<br>HCD | Value<br>(Default) | Comment                                                                                       |
|-----------|--------|-------------------|--------------------|-----------------------------------------------------------------------------------------------|
| InputData | 7:0    | R/W               | Xh                 | This bit retains the data that is written to I/O ports 60h and 64h when emulation is enabled. |
| Reserved  | 31 : 8 | _                 | Xh                 | Reserved                                                                                      |

## Register: HceOutput

| Field      | bit    | Read/Write<br>HCD | Value<br>(Default) | Comment                                                                                                                |
|------------|--------|-------------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| OutputData | 7:0    | R/W               | Xh                 | This bit retains the data that is returned when the application software reads from port 60h and emulation is enabled. |
| Reserved   | 31 : 8 | _                 | Xh                 | Reserved                                                                                                               |

# Register: HceStatus

| Field          | bit    | Read/Write<br>HCD | Value<br>(Default) | Comment                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|--------|-------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OutputFull     | 0      | R/W               | Ob                 | When I/O port 60h is read, "0" is set by the HC. When<br>IRQEn has been set and AuxOutputFull has been set to<br>"0", IRQ1 occurs as long as this bit's value is "1". When<br>IRQEn has been set and AuxOutputFull has been set to<br>"1", IRQ12 occurs as long as this bit's value is "1". When<br>this bit's value is "0" and HceControl's CharacterPending<br>value is "1", the emulation interrupt condition has been<br>met. |
| InputFull      | 1      | R/W               | Ob                 | "1" is set to this bit during an I/O write operation to<br>address 60h and 64h, except in the case of the GateA20<br>sequence. When this bit's value is "1", the emulation<br>interrupt condition has been met as long as emulation is<br>enabled.                                                                                                                                                                                |
| Flag           | 2      | R/W               | 0b                 | This bit is used as a system flag which ordinary software uses to indicate warm/cold boot status.                                                                                                                                                                                                                                                                                                                                 |
| CmdData        | 3      | R/W               | 0b                 | "0" is set by the HC when writing to port 60h and "1" is set<br>by the HC when writing to port 64h.                                                                                                                                                                                                                                                                                                                               |
| Inhibit Switch | 4      | R/W               | 0b                 | This bit indicates the status of the keyboard inhibit switch.<br>It is set when the keyboard is disabled (inhibit status).                                                                                                                                                                                                                                                                                                        |
| AuxOutputFull  | 5      | R/W               | 0b                 | "1" is set to OutputFull when this bit is set to "1". IRQ12 is always asserted when the IRQEn bit has been set.                                                                                                                                                                                                                                                                                                                   |
| Timeout        | 6      | R/W               | 0b                 | This bit is used to indicate a timeout condition.                                                                                                                                                                                                                                                                                                                                                                                 |
| Parity         | 7      | R/W               | 0b                 | This bit indicates a keyboard/mouse data parity error.                                                                                                                                                                                                                                                                                                                                                                            |
| Reserved       | 31 : 9 | _                 | Xh                 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |

## **Register: HceControl**

|                    |        | Read/Write | Value     |                                                                                                                                                                                                                                                                                                                                           |
|--------------------|--------|------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field              | bit    | HCD        | (Default) | Comment                                                                                                                                                                                                                                                                                                                                   |
| EmulationEnable    | 0      | R/W        | Ob        | When this bit's value is "1", the host controller is able to<br>perform legacy emulation. The host controller decodes<br>access to I/O registers 60h and 64h and IRQ1 or IRQ12<br>occur if the access is acceptable. The host controller may<br>also generate an emulation interrupt when necessary to<br>call up the emulation software. |
| EmulationInterrupt | 1      | R          | _         | This bit is used to passively decode emulation interrupt conditions. This bit's value becomes "1" when emulation interrupt status is ON.                                                                                                                                                                                                  |
| CharacterPending   | 2      | R/W        | 0b        | When this bit has been set, an emulation interrupt occurs if the HceStatus register's OutputFull bit's value is "0".                                                                                                                                                                                                                      |
| IRQEn              | 3      | R/W        | Ob        | When this bit has been set, the host controller generates IRQ1 or IRQ12 if the HceStatus register's OutputFull bit's value is "1". Specifically, IRQ1 occurs when the HceStatus register's AuxOutputFull bit's value is "0" and IRQ12 occurs when it is "1".                                                                              |
| ExternalIRQEn      | 4      | R/W        | 0b        | When this bit's value is "1", an emulation interrupt is<br>triggered by IRQ1 and IRQ12 from the keyboard<br>controller. The function that controls this bit does not<br>depend on the setting of the EmulationEnable bit in this<br>register.                                                                                             |
| GateA20Sequence    | 5      | R/W        | Ob        | When D1h is written to I/O port 64h, this bit is set by the HC. When a value other than D1h is written to I/O port 64h, this bit is cleared.                                                                                                                                                                                              |
| IRQ1Active         | 6      | R/W        | 0b        | This bit indicates when a positive transition has occurred<br>for IRQ1 from the keyboard controller. Software writes "1"<br>to this bit in order to clear this setting (to "0"). Nothing<br>occurs when software writes "0" to this bit.                                                                                                  |
| IRQ12Active        | 7      | R/W        | 0b        | This bit indicates when a positive transition has occurred<br>for IRQ12 from the keyboard controller. Software writes<br>"1" to this bit in order to clear this setting (to "0"). Nothing<br>occurs when software writes "0" to this bit.                                                                                                 |
| A20State           | 8      |            | 0b        | This bit indicates the current status of the keyboard<br>controller's GateA20. When GateA20Sequence is active,<br>this bit is used for comparison with the value that was<br>written to 60h.                                                                                                                                              |
| Reserved           | 31 : 9 | _          | _         | This bit is reserved. It must always be set to "0".                                                                                                                                                                                                                                                                                       |

## **CHAPTER 6 ELECTRICAL CHARACTERISTICS**

# 6.1 Buffer List

- 5 V schmitt buffer RST, SCLK, AT, LEGC
- 5 V IoL = 12 mA N-ch Open Drain buffer SMI
- 5 V input buffer RCVBE
- 5 V excessive through current prevention buffer OCI (2:1), IRI1, IRI2
- 5 V IoL = 6 mA Output buffer PPON (2:1), WAKE
- 5 V IoL = 6 mA N-ch Open Drain buffer IRO1, IRO2, A20S
- 5 V PCI interface (3-V PCI interface with 5-V maximum voltage circuit) AD (31:00), CBE (3:0), PAR, FRAME, IRDY, TRDY, STOP, IDSEL, DEVSEL, REQ, GNT, PERR, SERR, INTA, PCLK, CRUN
- USB interface
   DP (2:1), DN (2:1)

Above, "5 V" refers to a 3-V buffer that is 5-V tolerant (has 5-V maximum voltage). Therefore, it is possible to have a 5-V connection for an external bus, but the output level will be only up to 3 V, which is the V<sub>DD</sub> voltage. Similarly, "5 V PCI" above refers to a PCI buffer that has a 5-V maximum voltage circuit which meets the 3-V PCI standard; it does not refer to a PCI buffer that meets the 5-V PCI standard.

## 6.2 Absolute Maximum Ratings

| Parameter                     | Symbol | Conditions                                                                                                                                              | Rating       | Unit |
|-------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------|
| Power supply voltage          | Vdd    |                                                                                                                                                         | –0.5 to +4.6 | V    |
| Input voltage, 5-V buffer     | Vı     | $\begin{array}{l} 3.0 \text{ V} \leq \text{V}_{\text{DD}} \leq 3.6 \text{ V} \\ \text{V}_{\text{I}} < \text{V}_{\text{DD}} + 3.0 \text{ V} \end{array}$ | -0.5 to +6.6 | V    |
| Output voltage, 5-V buffer    | Vo     | $\begin{array}{l} 3.0 \ V \leq V_{DD} \leq 3.6 \ V \\ V_{O} < V_{DD} + 3.0 \ V \end{array}$                                                             | -0.5 to +6.6 | V    |
| USB common mode voltage       | Vсм    |                                                                                                                                                         | -0.5 to +3.8 | V    |
| Operating ambient temperature | TA     |                                                                                                                                                         | 0 to +70     | °C   |
| Storage temperature           | Tstg   |                                                                                                                                                         | –65 to +150  | °C   |

Table 6-1. Absolute Maximum Ratings

Caution Product quality may deteriorate if an absolute maximum rating is exceeded for even one parameter or even momentarily. Absolute maximum ratings are the highest values at which physical damage will not occur. Therefore, be sure that none of these maximum ratings are exceeded when using this product.

## 6.3 Recommended Operating Conditions

#### Table 6-2. Recommended Operating Conditions

| Parameter           | Symbol | Conditions       | MIN | TYP | MAX | Unit |
|---------------------|--------|------------------|-----|-----|-----|------|
| Operating voltage   | Vdd    |                  | 3.0 | 3.3 | 3.6 | V    |
| Input voltage       | Vı     | Except DP/DN pin | 0   |     | Vdd | V    |
| DP/DN input voltage | Viu    |                  | 0   |     | 3.3 | V    |

## 6.4 Pin Capacitance

#### Table 6-3. Pin Capacitance

| Parameter                       | Symbol | Conditions                        | MIN | MAX | Unit |
|---------------------------------|--------|-----------------------------------|-----|-----|------|
| Input capacitance, 5-V buffer   | Cı     | $V_{DD} = 0 V, T_A = 25^{\circ}C$ | 9   | 12  | pF   |
| Output capacitance, 5-V buffer  | Co     | fc = 1 MHz                        | 9   | 12  | pF   |
| I/O capacitance, 5-V buffer     | Сю     | Unmeasured pins returned to 0 V   | 9   | 12  | pF   |
| PCI clock input pin capacitance | Cclk   |                                   | 9   | 12  | pF   |
| PCI IDSEL input pin capacitance | CIDSEL |                                   |     | 8   | pF   |
| Pin inductance                  | Lpin   |                                   |     | 20  | nH   |
| DPx/DNx pin capacitance         | CIN    |                                   |     | 20  | pF   |

# 6.5 DC Characteristics ( $V_{DD}$ = 3.0 V to 3.6 V, $T_A$ = 0 to +70°C)

## Table 6-4. DC Characteristics

| Parameter                  | Symbol | Conditions                          | MIN | MAX | Unit |
|----------------------------|--------|-------------------------------------|-----|-----|------|
| Static current consumption | IDDSL  | PCI/USB clock is stopped, RCVBE = L |     | 300 | μA   |
|                            | Iddsh  | PCI/USB clock is stopped, RCVBE = H |     | 8   | mA   |

## Table 6-5. DC Characteristics (PCI Interface Block)

| Parameter                 | Symbol | Conditions     | MIN     | MAX       | Unit |
|---------------------------|--------|----------------|---------|-----------|------|
| High-level input voltage  | Vih    |                | 0.5 Vdd | Vdd + 0.5 | V    |
| Low-level input voltage   | Vil    |                | -0.5    | 0.3 Vdd   | V    |
| Input leakage current     | lii    | 0 < Vin < VDD  |         | ±10       | μA   |
| High-level output voltage | Voh    | Ιουτ = -500 μΑ | 0.9 Vdd |           | V    |
| Low-level output voltage  | Vol    | Ιουτ = 1500 μΑ |         | 0.1 Vdd   | V    |

Figure 6-1. Vo vs. lo (PCI Buffer)

(a) Vol VS Iol (VDD = 3.0 V)



**Remark** Min value (process = worst,  $T_A = 70^{\circ}C$ ), max value (process = best,  $T_A = 0^{\circ}C$ )



(b) Voh vs Ioh (VDD = 3.0 V)

**Remark** Min value (process = worst,  $T_A = 70^{\circ}C$ ), max value (process = best,  $T_A = 0^{\circ}C$ )





**Remark** Min value (process = worst,  $T_A = 70^{\circ}C$ ), max value (process = best,  $T_A = 0^{\circ}C$ )



(d) Voh vs Ioh (VDD = 3.6 V)

**Remark** Min value (process = worst,  $T_A = 70^{\circ}C$ ), max value (process = best,  $T_A = 0^{\circ}C$ )

| Parameter                                | Symbol | Conditions            | MIN | MAX | Unit |
|------------------------------------------|--------|-----------------------|-----|-----|------|
| Data line high impedance leakage current | Ιιο    | 0 V < VIN < 3.3 V     |     | ±10 | μA   |
| Differential input sensitivity           | Vdi    | (D+) – (D–)           | 0.2 |     | V    |
| Common mode voltage                      | Vсм    |                       | 0.8 | 2.5 | V    |
| Single-ended 0 reception threshold       | Vse    |                       | 0.8 | 2.0 | V    |
| High-level output voltage                | Vон    | R∟ of 15 kΩ to GND    | 2.8 | 3.6 | V    |
| Low-level output voltage                 | Vol    | R∟ of 1.5 kΩ to 3.6 V |     | 0.3 | V    |
| Output signal crossover point voltage    | Vcrs   |                       | 1.3 | 2.0 | V    |
| Output pin impedance                     | Zdrv   |                       | 28  | 43  | Ω    |

## Table 6-6. DC Characteristics (USB Interface Block)

**Remark** The output pin impedance is a value for discrete buffers. In other words, an external series resistance is not required.



Figure 6-2. Vcm (Common Mode Voltage) vs. VDI (Differential Input Sensitivity)

| Parameter                               | Symbol | Conditions                                                                 | MIN         | MAX  | Unit     |
|-----------------------------------------|--------|----------------------------------------------------------------------------|-------------|------|----------|
| High-level input voltage<br>5-V buffer  | Vін    |                                                                            | 2.0         | 5.5  | V        |
| Low-level input voltage<br>5-V buffer   | VIL    |                                                                            | 0           | 0.8  | V        |
| Positive trigger voltage<br>5-V buffer  | Vp     |                                                                            | 2.2         | 2.55 | V        |
| Negative trigger voltage<br>5-V buffer  | VN     |                                                                            | 0.84        | 1.01 | V        |
| Hysteresis voltage<br>5-V buffer        | Vн     |                                                                            | 1.1         | 1.5  | V        |
| Off-state output current<br>5-V buffer  | loz    | Vo = VDD or GND                                                            |             | ±14  | μA       |
| Input leakage current<br>5-V buffer     | lı.    | Vo = VDD or GND                                                            |             | ±10  | μA       |
| High-level output current<br>5-V buffer | Іон    | Vo = 0.4 V                                                                 | -3.0        |      | mA       |
| Low-level output current<br>5-V buffer  | lo∟    | $V_{O} = V_{DD} - 0.4 V$ $V_{O} = V_{DD} - 0.4 V$                          | 12.0<br>6.0 |      | mA<br>mA |
| Output run-off current<br>5-V buffer    | IR     | $V_{PU} = 5.5 \text{ V}, \text{ R}_{PU} = 2 \text{ k}\Omega$<br>Vo = 3.0 V |             | 14   | μA       |

## Table 6-7. DC Characteristics (Control Pin Block)

# 6.6 Power Consumption

| Table 6-8. | Power | Consumption | Characteristics |
|------------|-------|-------------|-----------------|
|------------|-------|-------------|-----------------|

| Parameter         | Symbol | Conditions                             | TYP | Unit |
|-------------------|--------|----------------------------------------|-----|------|
| Power consumption | Pwdo_o | Device state = D0, USB = Operational   | 500 | mW   |
|                   | Pwdo_s | Device state = D0, USB = Suspend/Reset | 150 | mW   |
|                   | Pwd2   | Device state = D2, USB = Suspend/Reset |     | mW   |
|                   | Pwd3   | Device state = D3, USB = Reset         | 100 | mW   |

**Remark** When the device state = D0, the clock is defined as it is during normal operation. When the device state = D2 or D3, the PCI clock is defined as when it is suspended.

## 6.7 System Clock Ratings

## Table 6-9. System Clock Ratings

| Parameter        | Symbol        | Ratings                 | Unit |
|------------------|---------------|-------------------------|------|
| Clock frequency  | fськ          | 48 ±500 PPM             | MHz  |
| Clock Duty cycle | <b>t</b> duty | ±10                     | %    |
| Input rise time  | tr            | 5 (from 0.4 V to 2.4 V) | ns   |
| Input fall time  | tr            | 5 (from 2.4 V to 0.4 V) | ns   |

# 6.8 AC Characteristics ( $V_{DD}$ = 3.0 V to 3.6 V, $T_A$ = 0 to +70°C)

# Table 6-10. AC Characteristics (PCI Interface Block)

| Parameter                                                                           | Symbol               | Conditions                                              | MIN   | MAX   | Unit  |
|-------------------------------------------------------------------------------------|----------------------|---------------------------------------------------------|-------|-------|-------|
| PCI clock cycle time                                                                | tcyc                 |                                                         | 30    |       | ns    |
| PCI clock pulse, high-level width                                                   | <b>t</b> high        |                                                         | 11    |       | ns    |
| PCI clock pulse, low-level width                                                    | tiow                 |                                                         | 11    |       | ns    |
| PCI clock, rise slew rate                                                           | Scr                  | 0.2 VDD to 0.6 VDD                                      | 1     | 4     | V/ns  |
| PCI clock, fall slew rate                                                           | Scf                  | 0.2 Vpd to 0.6 Vpd                                      | 1     | 4     | V/ns  |
| PCI reset active time<br>(vs. power supply stability)                               | trst                 |                                                         | 1     |       | ms    |
| PCI reset active time (vs. CLK Start)                                               | trst-clk             |                                                         | 100   |       | μs    |
| Output float delay time (vs. RST $\downarrow$ )                                     | t <sub>rst-off</sub> |                                                         |       | 40    | ns    |
| PCI reset rise slew rate                                                            | Srr                  |                                                         | 50    |       | mV/ns |
| PCI bus signal output time<br>(vs. PCLK↑) <sup>Note 1</sup>                         | tval                 |                                                         |       | T.B.D | ns    |
| PCI point-to-point signal output time<br>(vs. PCLK <sup>^</sup> ) <sup>Note 1</sup> | $t_{val}$ (ptp)      | REQ                                                     |       | T.B.D | ns    |
| Output delay time (vs. PCLK <sup>↑</sup> )                                          | ton                  |                                                         |       | T.B.D | ns    |
| Output float delay time (vs. PCLK $\uparrow$ )                                      | toff                 |                                                         |       | T.B.D | ns    |
| PCI output rise slew rate <sup>Note 2</sup>                                         | slewr                | 0.2 VDD to 0.6 VDD                                      | 1     | 4     | V/ns  |
| PCI output fall slew rate <sup>Note 2</sup>                                         | slew                 | 0.2 VDD to 0.6 VDD                                      | 1     | 4     | V/ns  |
| Input setup time (vs. PCLK <sup>↑</sup> )                                           | tsu                  |                                                         | T.B.D |       | ns    |
| Point-to-point input setup time (vs. PCLK <sup>↑</sup> )                            | tsu (ptp)            | GNT                                                     | T.B.D |       | ns    |
| Input hold time                                                                     | th                   |                                                         | T.B.D |       | ns    |
| PCI clock reset allowable time<br>(vs. CRUN↓)                                       | tcrun-clk            |                                                         |       | 5     | μs    |
| GNT assert allowable time (vs. CRUN $\downarrow)$                                   | tcrun-gnt            | vs. ISO transaction that is at least 64 bytes in length |       | 7     | μs    |
| INTA, SMI, WAKE cancellation time                                                   | tintc                | From when register is set                               |       | 170   | ns    |

Notes 1. The measurement conditions for tval are as follows.



2. The measurement conditions for the PCI output slew rate are the same as (a) and (b) above.

| Table 6-11. AC Characteristics (USB Interface Block) | Table 6-11. | 1. AC Characteristics (USB Interface Block) |
|------------------------------------------------------|-------------|---------------------------------------------|
|------------------------------------------------------|-------------|---------------------------------------------|

| Parameter                                                                                                                                           | Symbol                               | Conditions                              | MIN                            | MAX                     | Unit                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-----------------------------------------|--------------------------------|-------------------------|----------------------|
| Disconnect decision time                                                                                                                            | Tdis                                 |                                         | 2.5                            |                         | μs                   |
| Connect decision time                                                                                                                               | Tcon                                 |                                         | 2.5                            |                         | μs                   |
| Rise time<br>Full speed<br>Low speed                                                                                                                | Tr                                   | CL = 50 pF<br>CL = 50 pF<br>CL = 350 pF | 4<br>75                        | 20<br>300               | ns<br>ns<br>ns       |
| Fall time<br>Full speed<br>Low speed                                                                                                                | Tr                                   | CL = 50 pF<br>CL = 50 pF<br>CL = 350 pF | 4<br>75                        | 20<br>300               | ns<br>ns<br>ns       |
| Rise/fall matching<br>Full speed<br>Low speed                                                                                                       | Тгғм                                 | (TR/TF)<br>(TR/TF)                      | 90<br>80                       | 110<br>120              | %<br>%               |
| Data rate<br>Full speed<br>Low speed                                                                                                                | Tdrate                               |                                         | 11.97<br>1.4775                | 12.03<br>1.5225         | Mbs<br>Mbs           |
| Frame time interval                                                                                                                                 | TFRAME                               |                                         | 0.9995                         | 1.0005                  | ms                   |
| Jitter generated by differential driver<br>Full speed<br>Next Transition<br>Paired Transition<br>Low speed<br>Next Transition<br>Paired Transition  | Тыл<br>Тол2<br>Тоол1<br>Тоол2        |                                         | -3.5<br>-4.0<br>-75<br>-45     | 3.5<br>4.0<br>75<br>45  | ns<br>ns<br>ns<br>ns |
| Transmitter EOP pulse width<br>Full speed<br>Low speed                                                                                              | Теорт                                |                                         | 160<br>1.25                    | 175<br>1.50             | ns<br>μs             |
| EOP pulse width skew<br>Full speed<br>Low speed                                                                                                     | Tdeop                                |                                         | -2<br>-40                      | 5<br>100                | ns<br>ns             |
| Differential receiver's allowable jitter<br>Full speed<br>Next Transition<br>Paired Transition<br>Low speed<br>Next Transition<br>Paired Transition | Tjr1<br>Tjr2<br>Tujr1<br>Tujr2       |                                         | -18.5<br>-9<br>-152<br>-200    | 18.5<br>9<br>152<br>200 | ns<br>ns<br>ns<br>ns |
| Receiver EOP pulse width<br>Full speed<br>Rejection value<br>Acceptance value<br>Low speed <sup>Note</sup><br>Rejection value<br>Acceptance value   | Teopr1<br>Teopr2<br>Teopr1<br>Teopr2 |                                         | ≤ 40<br>> 40<br>≤ 330<br>> 330 |                         | ns<br>ns<br>ns<br>ns |

**Note** This applies up until the EOF1 token that defines the end of the Frame in the HUB. The rated Full Speed is applied between EOF1 and EOF2.

## 7.1 PCI Clock





## 7.2 PCI Reset





# 7.3 PCI Output Timing



Figure 7-3. PCI Output Timing

## 7.4 PCI Input Timing





7.5 PCI Clock Reset

Figure 7-5. PCI Clock Reset



## 7.6 CRUN vs. GNT



## 7.7 USB Device Disconnect Detection





## 7.8 USB Full Speed Device Connect Detection



Figure 7-8. USB Full Speed Device Connect Detection

## 7.9 USB Low Speed Device Connect Detection



Figure 7-9. USB Low Speed Device Connect Detection

## 7.10 USB Signal Rise/Fall Timing





# 7.11 USB Differential Signal





## 7.12 USB EOP Signal



Figure 7-12. USB EOP Signal

# 7.13 USB Differential Receiver Allowable Jitter





[MEMO]

## CHAPTER 8 USB HOST CONTROLLER USE METHOD

## 8.1 USB Host Controller Peripheral Circuit Example

This USB HC can be generally divided into four blocks: the PCI interface block, USB interface block, Legacy interface block, and test pin block. Since the PCI interface block complies with the **PCI Local Bus Specification Revision 2.1** and **PCI Mobile Design Guide Revision 1.0**, refer to these specifications before designing external circuits or peripheral circuits. The test pin block should be left with all pins unconnected on the board. The following diagrams show a peripheral circuit example in which this host controller is mounted onto an Add-in Board. The circuits in this example are for reference only: they are not guaranteed as peripheral circuits.



Figure 8-1. Circuit Example of USB Interface Block



## Figure 8-2. Circuit Example of Legacy Interface Block

The jumper settings are shown below.

| Pin  | No Legacy | Legacy | CLKRUN  |
|------|-----------|--------|---------|
| A20S | Open      | A20S   |         |
| IRI1 | Low       | IRI1   |         |
| IRI2 | Low       | IRI2   |         |
| IRO1 | Open      | IRO1   |         |
| IRO2 | Open      | IRO2   |         |
| LEGC | Low       | High   |         |
| AT   | Low       | High   |         |
| CRUN | Low       | Low    | CLKRUN# |

| Table 8-1. | Jumper | Settings |
|------------|--------|----------|
|------------|--------|----------|



# Facsimile Message

Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free and up-to-date, we readily accept that errors may occur. Despite all the care and precautions we've taken, you may encounter problems in the documentation. Please complete this form whenever you'd like to report errors or suggest improvements to us.

| FAX |
|-----|

Address

Tel.

From:

Name

Company

Thank you for your kind support.

| North America<br>NEC Electronics Inc.<br>Corporate Communications Dept.<br>Fax: 1-800-729-9288<br>1-408-588-6130 | Hong Kong, Philippines, Oceania<br>NEC Electronics Hong Kong Ltd.<br>Fax: +852-2886-9022/9044 | Asian Nations except Philippines<br>NEC Electronics Singapore Pte. Ltd.<br>Fax: +65-250-3583 |
|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Europe<br>NEC Electronics (Europe) GmbH<br>Technical Documentation Dept.<br>Fax: +49-211-6503-274                | <b>Korea</b><br>NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Fax: 02-528-4411            | Japan<br>NEC Semiconductor Technical Hotline<br>Fax: 044-548-7900                            |
| South America<br>NEC do Brasil S.A.<br>Fax: +55-11-6465-6829                                                     | <b>Taiwan</b><br>NEC Electronics Taiwan Ltd.<br>Fax: 02-719-5951                              |                                                                                              |

I would like to report the following error/make the following suggestion:

Document title: \_\_\_\_

Document number: \_\_\_\_

\_\_\_\_\_ Page number: \_\_\_\_\_

If possible, please fax the referenced page or drawing.

| <b>Document Rating</b> | Excellent | Good | Acceptable | Poor |
|------------------------|-----------|------|------------|------|
| Clarity                |           |      |            |      |
| Technical Accuracy     |           |      |            |      |
| Organization           |           |      |            |      |